按照多个属性(包括嵌套属性)对对象进行分组,并汇总它们的值。
创始人
2024-08-23 20:00:12
0

在Python中,可以使用itertools.groupby函数和collections.defaultdict类来按照多个属性对对象进行分组,并汇总它们的值。

首先,导入必要的模块:

import itertools
from collections import defaultdict

假设有一个对象列表objects,每个对象都有多个属性,例如namecategoryvalue。我们想要按照namecategory属性对对象进行分组,并汇总它们的value属性。

objects = [
    {'name': 'object1', 'category': 'category1', 'value': 10},
    {'name': 'object2', 'category': 'category2', 'value': 20},
    {'name': 'object1', 'category': 'category1', 'value': 30},
    {'name': 'object2', 'category': 'category1', 'value': 40},
    {'name': 'object3', 'category': 'category2', 'value': 50}
]

使用itertools.groupby函数按照namecategory属性对对象进行分组:

grouped_objects = itertools.groupby(objects, key=lambda x: (x['name'], x['category']))

然后,使用collections.defaultdict类来汇总每个组的value属性:

grouped_values = defaultdict(int)

for key, group in grouped_objects:
    for obj in group:
        grouped_values[key] += obj['value']

最后,打印汇总结果:

for key, value in grouped_values.items():
    print(key, value)

完整的示例代码如下:

import itertools
from collections import defaultdict

objects = [
    {'name': 'object1', 'category': 'category1', 'value': 10},
    {'name': 'object2', 'category': 'category2', 'value': 20},
    {'name': 'object1', 'category': 'category1', 'value': 30},
    {'name': 'object2', 'category': 'category1', 'value': 40},
    {'name': 'object3', 'category': 'category2', 'value': 50}
]

grouped_objects = itertools.groupby(objects, key=lambda x: (x['name'], x['category']))

grouped_values = defaultdict(int)

for key, group in grouped_objects:
    for obj in group:
        grouped_values[key] += obj['value']

for key, value in grouped_values.items():
    print(key, value)

输出结果:

('object1', 'category1') 40
('object2', 'category2') 20
('object2', 'category1') 40
('object3', 'category2') 50

以上示例代码按照namecategory属性对对象进行了分组,并汇总了它们的value属性。你可以根据自己的需求修改示例代码来适应不同的对象属性和汇总方式。

相关内容

热门资讯

透视神器!fishpoker透... 透视神器!fishpoker透视(透视)真是有挂(详细辅助黑科技教程)1、许多玩家不知道辅助软件怎么...
透视脚本!wepokerh5破... 透视脚本!wepokerh5破解(透视)本来是有挂(详细辅助软件教程)1、ai辅助优化,发牌逻辑科技...
透视好友房!pokemmo辅助... 透视好友房!pokemmo辅助器脚本下载(透视)原来存在有挂(详细辅助必赢方法)1、系统规律教程、辅...
透视模拟器!德普之星透视辅助(... 透视模拟器!德普之星透视辅助(透视)确实存在有挂(详细辅助微扑克教程)1、首先打开德普之星透视辅助最...
透视私人局!pokemmo手机... 透视私人局!pokemmo手机版脚本(透视)原来有挂(详细辅助详细教程);1. ai辅助创建新账号,...
透视科技!智星菠萝可以辅助吗(... 透视科技!智星菠萝可以辅助吗(透视)竟然真的是有挂(详细辅助攻略教程);1、起透看视 智星菠萝可以辅...
透视系统!wepoker透视脚... 透视系统!wepoker透视脚本免费下载pc(透视)果然是真的有挂(详细辅助2025版教程);1、完...
透视有挂!约局吧能不能开挂(透... 透视有挂!约局吧能不能开挂(透视)竟然真的是有挂(详细辅助可靠教程);1、点击下载安装,插件透视分类...
透视辅助!佛手大菠萝辅助(透视... 透视辅助!佛手大菠萝辅助(透视)一贯有挂(详细辅助AI教程)所有人都在同一条线上,像星星一样排成一排...
透视规律!如何下载德普之星辅助... 透视规律!如何下载德普之星辅助软件(透视)确实是真的有挂(详细辅助AA德州教程);1、机器人多个强度...