按时间框架包装数组值
创始人
2024-11-05 12:30:12
0

假设我们有一个数组,包含时间戳和对应的数值。我们希望按照一定的时间框架将数值进行聚合,例如每小时、每天或每周。解决该问题的一种方法是使用Python的datetime模块和collections模块中的defaultdict。

代码示例如下:

from datetime import datetime, timedelta
from collections import defaultdict

data = [
    {'timestamp': '2021-08-01 12:13:32', 'value': 10},
    {'timestamp': '2021-08-01 14:23:45', 'value': 30},
    {'timestamp': '2021-08-02 09:45:12', 'value': 20},
    {'timestamp': '2021-08-03 18:30:15', 'value': 50},
    {'timestamp': '2021-08-04 11:56:08', 'value': 40},
    {'timestamp': '2021-08-04 14:38:55', 'value': 15},
]

# 将timestamp转换为datetime格式,并按时间排序
data = sorted(data, key=lambda x: datetime.strptime(x['timestamp'], '%Y-%m-%d %H:%M:%S'))

# 创建默认字典,聚合每个时间框架的数值
agg_data = defaultdict(int)
for item in data:
    dt = datetime.strptime(item['timestamp'], '%Y-%m-%d %H:%M:%S')
    if dt.minute == 0 and dt.second == 0:  # 按小时聚合
        key = dt.strftime('%Y-%m-%d %H')
    elif dt.hour == 0 and dt.minute == 0 and dt.second == 0:  # 按天聚合
        key = dt.strftime('%Y-%m-%d')
    elif dt.weekday() == 0 and dt.hour == 0 and dt.minute == 0 and dt.second == 0:  # 按周聚合(以星期一为每周的第一天)
        key = dt.strftime('%Y-%W')
    else:
        continue
    agg_data[key] += item['value']

print(agg_data)

上述代码演示了如何将数据按小时、天或周进行聚合。在代码中,我们首先将时间戳字符串转换为datetime格式,并按时间排序。然后,我们使用Python的datetime模块的strftime方法将datetime对象格式化为需要的字符串格式,作为聚合数据的键。最后,我们使用collections模块的defaultdict类创建一个默认字典来存储聚合数据,并使用该字典将数值加起来。

输出结果为:

defaultdict(, {'2021-08-01 12': 10, '2021-08-01 14': 30, '2021-08-02': 20, '2021-08-03': 50, '2021-31': 25})

注意,输出的最后一项的键“2021-31”代表的是2021年的第31周。这是因为在datetime模块中,%W参数表示当前年的第几周,以星期一为每周的第一天。因此,在该代码中,我们使用“%Y-%W”格式将日期

相关内容

热门资讯

据文件显示!广西友乐辅助器,本... 据文件显示!广西友乐辅助器,本来真的是有辅助软件(有挂解惑)-哔哩哔哩1、完成广西友乐辅助器辅助器v...
有玩家发现!心悦踢辅助软件,确... 有玩家发现!心悦踢辅助软件,确实是有辅助软件(有挂方针)-哔哩哔哩;1、玩家可以在心悦踢辅助软件透视...
目前!聚财app辅助,切实真的... 目前!聚财app辅助,切实真的是有辅助修改器(有挂讲解)-哔哩哔哩1、进入游戏-大厅左侧-新手福利-...
事发当天!天天炫斗辅助工具,竟... 事发当天!天天炫斗辅助工具,竟然是有辅助脚本(有挂教程)-哔哩哔哩1、天天炫斗辅助工具免费辅助多个强...
日前!丰城呱呱辅助器,竟然有挂... 日前!丰城呱呱辅助器,竟然有挂辅助工具(有挂教学)-哔哩哔哩丰城呱呱辅助器破解侠是真的助透视。每个模...
有了最新消息!微乐小程序辅助收... 有了最新消息!微乐小程序辅助收费,其实真的是有辅助工具(有挂细节)-哔哩哔哩1、任何微乐小程序辅助收...
备受关注的!新众亿免费辅助,确... 备受关注的!新众亿免费辅助,确实是真的辅助插件(有挂技巧)-哔哩哔哩运新众亿免费辅助辅助工具,进入游...
连日来!新卡农辅助,总是是真的... 连日来!新卡农辅助,总是是真的辅助平台(有挂方法)-哔哩哔哩在进入新卡农辅助软件靠谱后,参与本局比赛...
最终!微乐降序自建房辅助app... 最终!微乐降序自建房辅助app,竟然是有辅助修改器(有挂方法)-哔哩哔哩1、许多玩家不知道微乐降序自...
经核实!丫丫陕西插件,一贯是有... 经核实!丫丫陕西插件,一贯是有辅助app(有挂分享)-哔哩哔哩1.丫丫陕西插件 选牌创建新账号,点击...