按照多个属性(包括嵌套属性)对对象进行分组,并汇总它们的值。
创始人
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属性。你可以根据自己的需求修改示例代码来适应不同的对象属性和汇总方式。

相关内容

热门资讯

曝光透视!哈糖大菠萝怎么挂!本... 曝光透视!哈糖大菠萝怎么挂!本来真的有辅助插件(竟然有挂)-哔哩哔哩1、超多福利:超高返利,海量正版...
专业透视!pokerworld... 专业透视!pokerworld破解版下载!真是一直总是有辅助软件(有挂秘诀)-哔哩哔哩1、让任何用户...
解密透视!德州真人透视脚本!果... 解密透视!德州真人透视脚本!果然有辅助app(有挂细节)-哔哩哔哩1、任何德州真人透视脚本透视是真的...
辅助透视!hardrock透视... 辅助透视!hardrock透视工具!其实真的是有辅助脚本(有挂秘笈)-哔哩哔哩1、金币登录送、破产送...
解密透视!pokermaste... 解密透视!pokermaster辅助器!果然真的是有辅助工具(有挂讲解)-哔哩哔哩1、pokerma...
必备透视!拱趴大菠萝有什么挂!... 必备透视!拱趴大菠萝有什么挂!果然真的是有辅助工具(有挂透视)-哔哩哔哩1、首先打开拱趴大菠萝有什么...
推荐透视!约局吧德州透视!确实... 推荐透视!约局吧德州透视!确实一直都是有辅助攻略(的确有挂)-哔哩哔哩1、约局吧德州透视辅助软件下载...
必备透视!拱趴大菠萝有什么挂!... 必备透视!拱趴大菠萝有什么挂!一直一直总是有辅助软件(有挂方式)-哔哩哔哩1)拱趴大菠萝有什么挂辅助...
科普透视!xpoker辅助工具... 科普透视!xpoker辅助工具!一贯是真的有辅助神器(确实有挂)-哔哩哔哩一、xpoker辅助工具游...
科普透视!德州真人透视脚本!本... 科普透视!德州真人透视脚本!本来存在有辅助技巧(有挂攻略)-哔哩哔哩德州真人透视脚本能透视中分为三种...