【发布时间】:2020-09-03 13:45:23
【问题描述】:
我有一个这样的数据集:
2020-09-02 02:22:14
2020-09-05 10:22:14
2020-09-03 06:22:14
2020-09-07 04:22:14
2020-09-02 11:22:14
2020-09-09 03:22:14
2020-09-03 10:22:14
2020-09-04 06:22:14
2020-09-02 07:22:14
2020-09-02 06:22:14
2020-09-02 10:22:14
我想要做的是每两个小时将时间戳分组在一起,例如:
[
02:00:00: ['2020-09-02 02:22:14', '2020-09-04 02:22:14'],
04:00:00: ['2020-09-07 04:22:14'],
06:00:00: ['2020-09-03 06:22:14', '2020-09-02 06:22:14'],
08:00:00: [] -- Empty array when no timestamp falls in that given range
10:00:00: [etc..] --up until 00:00:00
]
我尝试过的:
const hello = _.groupBy(something, (date) => {
const timeStamp = moment(date).add(30, 'minutes').startOf('hour').format('HH:mm:ss');
return moment('1960-02-02 ' + timeStamp).format('YYYY-MM-DD HH:mm:ss');
});
返回以下内容:
2020-09-12 02:00:00: (2) ["2020-09-02 02:22:14", "2020-09-02 02:22:14"]
2020-09-12 03:00:00: ["2020-09-09 03:22:14"]
2020-09-12 04:00:00: ["2020-09-07 04:22:14"]
2020-09-12 06:00:00: (3) ["2020-09-03 06:22:14", "2020-09-04 06:22:14", "2020-09-02 06:22:14"]
2020-09-12 07:00:00: ["2020-09-02 07:22:14"]
2020-09-12 10:00:00: (3) ["2020-09-05 10:22:14", "2020-09-03 10:22:14", "2020-09-02 10:22:14"]
2020-09-12 11:00:00: ["2020-09-02 11:22:14"]
这不是我想要的,我已经尝试查看其他一些帖子以获得一个想法,但任何帮助将不胜感激。
【问题讨论】:
标签: javascript momentjs lodash underscore.js