按多个字段对行进行分组,并返回其他字段。
创始人
2024-10-14 03:30:39
0

在Python中,可以使用itertools.groupby()函数和operator.itemgetter()函数对行进行多个字段的分组,并返回其他字段。

以下是一个示例代码:

from itertools import groupby
from operator import itemgetter

# 样本数据
data = [
    {'name': 'Alice', 'age': 25, 'gender': 'Female'},
    {'name': 'Bob', 'age': 30, 'gender': 'Male'},
    {'name': 'Charlie', 'age': 25, 'gender': 'Male'},
    {'name': 'Dave', 'age': 30, 'gender': 'Male'},
    {'name': 'Eve', 'age': 25, 'gender': 'Female'}
]

# 按多个字段进行分组
data.sort(key=itemgetter('age', 'gender'))  # 先按age字段排序,再按gender字段排序
groups = groupby(data, key=itemgetter('age', 'gender'))

# 打印分组结果和其他字段
for key, group in groups:
    print(f'Group: {key}')
    for item in group:
        print(f'Name: {item["name"]}')
    print()

输出结果为:

Group: (25, 'Female')
Name: Alice
Name: Eve

Group: (25, 'Male')
Name: Charlie

Group: (30, 'Male')
Name: Bob
Name: Dave

这个示例代码首先定义了一个包含样本数据的data列表,每个元素是一个字典,表示一个人的信息。然后,使用itemgetter('age', 'gender')指定了按agegender字段进行排序和分组的规则。接下来,使用sort()函数对数据进行排序,然后使用groupby()函数进行分组。最后,使用一个循环遍历每个分组并输出对应的字段值。

相关内容

热门资讯

玩家实测!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私人局俱乐部辅助系统规律,只需要输入自己想要的开挂功能,一键便可以生成出微扑克专...