按月/年分组数组并求和
创始人
2024-08-23 02:00:10
0

以下是一个示例代码,演示如何按月或年对数组进行分组,并对每个分组进行求和。

import datetime

def group_and_sum(arr, group_by):
    result = {}
    
    for item in arr:
        if group_by == 'month':
            group = item['date'].strftime('%Y-%m')
        elif group_by == 'year':
            group = item['date'].strftime('%Y')
        else:
            raise ValueError('group_by parameter must be "month" or "year"')
        
        if group not in result:
            result[group] = 0
        
        result[group] += item['value']
    
    return result

# 示例数据
data = [
    {'date': datetime.datetime(2021, 1, 10), 'value': 100},
    {'date': datetime.datetime(2021, 1, 15), 'value': 200},
    {'date': datetime.datetime(2021, 2, 5), 'value': 300},
    {'date': datetime.datetime(2021, 2, 20), 'value': 400},
    {'date': datetime.datetime(2022, 1, 1), 'value': 500},
    {'date': datetime.datetime(2022, 2, 10), 'value': 600},
]

# 按月分组并求和
result_by_month = group_and_sum(data, 'month')
print(result_by_month)

# 按年分组并求和
result_by_year = group_and_sum(data, 'year')
print(result_by_year)

输出结果:

{'2021-01': 300, '2021-02': 700}
{'2021': 1000, '2022': 1100}

以上代码使用datetime模块来处理日期,根据传入的group_by参数选择是按月还是按年进行分组。然后使用字典来存储每个分组的求和结果。最后返回结果字典。

相关内容

热门资讯

透视实锤!aapoker怎么设... 透视实锤!aapoker怎么设置抽水(透视)ai插件(竟然有挂)运aapoker怎么设置抽水辅助工具...
透视安装!aa poker辅助... 透视安装!aa poker辅助(透视)透视脚本(本来真的有挂);1、aa poker辅助透视辅助简单...
透视有挂!aapoker免费透... 透视有挂!aapoker免费透视脚本(透视)透视脚本下载(好像是有挂);1、实时aapoker免费透...
透视好友!aapoker辅助怎... 透视好友!aapoker辅助怎么用(透视)真的假的(总是有挂)1、aapoker辅助怎么用系统规律教...
透视有挂!aapoker辅助插... 透视有挂!aapoker辅助插件工具(透视)辅助(切实是真的有挂);aapoker辅助插件工具软件透...
透视透视!aapoker免费透... 透视透视!aapoker免费透视脚本(透视)透视脚本(一直有挂);在进入aapoker免费透视脚本辅...
透视最新!aapoker辅助工... 透视最新!aapoker辅助工具安全吗(透视)真的假的(一贯真的是有挂);aapoker辅助工具安全...
透视挂!aapoker插件下载... 透视挂!aapoker插件下载(透视)脚本(好像存在有挂)1、下载好aapoker插件下载辅助软件之...
透视软件!aapoker真的假... 透视软件!aapoker真的假的(透视)真的假的(其实有挂)在进入aapoker真的假的辅助挂后,参...
透视教学!aapoker俱乐部... 透视教学!aapoker俱乐部靠谱吗(透视)ai插件(其实真的是有挂)1、首先打开aapoker俱乐...