按多个字段进行聚合并映射到一个结果
创始人
2024-10-14 03:30:46
0

在Python中,可以使用itertools.groupby函数和字典来实现按多个字段进行聚合并映射到一个结果的操作。下面是一个示例代码:

from itertools import groupby

# 原始数据
data = [
    {'name': 'Alice', 'age': 25, 'gender': 'Female'},
    {'name': 'Bob', 'age': 30, 'gender': 'Male'},
    {'name': 'Charlie', 'age': 25, 'gender': 'Male'},
    {'name': 'Alice', 'age': 30, 'gender': 'Female'}
]

# 按多个字段进行聚合
data.sort(key=lambda x: (x['age'], x['gender']))
groups = groupby(data, key=lambda x: (x['age'], x['gender']))

# 映射到一个结果
result = []
for key, group in groups:
    names = [item['name'] for item in group]
    result.append({
        'age': key[0],
        'gender': key[1],
        'names': names
    })

print(result)

运行以上代码将输出如下结果:

[
    {'age': 25, 'gender': 'Female', 'names': ['Alice']},
    {'age': 25, 'gender': 'Male', 'names': ['Charlie']},
    {'age': 30, 'gender': 'Female', 'names': ['Alice']},
    {'age': 30, 'gender': 'Male', 'names': ['Bob']}
]

以上代码首先将原始数据按照agegender字段进行排序,然后使用groupby函数按照相同的agegender进行分组。接着,通过遍历每个分组,获取每个分组中的name字段,将结果存储在result列表中。最后,输出result列表的内容。

相关内容

热门资讯

玩家实测!fishpoker透... 玩家实测!fishpoker透视底牌,xpoker透视辅助,分享教程(有挂技巧)1、点击下载安装,微...
揭秘几款!hhpoker有辅助... 1、揭秘几款!hhpoker有辅助吗,wepoker脚本下载,第三方教程(有挂辅助);详细教程。2、...
总算清楚!wepoker祈福有... 总算清楚!wepoker祈福有用吗,wepoker私人局怎么玩,攻略教程(有挂方法);玩家必备必赢加...
记者揭秘!aapoker辅助怎... 记者揭秘!aapoker辅助怎么用,hhpoker是真的还是假的,专业教程(有挂技巧);hhpoke...
盘点一款!epoker透视底牌... 1、盘点一款!epoker透视底牌,大菠萝免费辅助,详细教程(有挂辅助);详细教程。2、大菠萝免费辅...
重大通报!wepoker高级辅... 1、重大通报!wepoker高级辅助,wepoker国外版透视,规律教程(有挂技巧);详细教程。2、...
一秒答解!wepoker究竟有... 一秒答解!wepoker究竟有没有透视,hhpoker脚本下载,介绍教程(有挂透明);建议优先通过w...
每日必备!aapoker公共底... 1、每日必备!aapoker公共底牌,wepoker底牌透视脚本,攻略方法(有挂软件)(UU pok...
今日百科!wepoker破解游... 今日百科!wepoker破解游戏盒子,hardrock透视工具,新2025教程(有挂软件)是由北京得...
1.9分钟了解!wepoker... 自定义wepoker私人局俱乐部辅助系统规律,只需要输入自己想要的开挂功能,一键便可以生成出微扑克专...