按照多个键对字典列表进行分组和聚合
创始人
2024-08-23 19:30:17
0

以下是一个示例代码,展示如何按照多个键对字典列表进行分组和聚合:

from collections import defaultdict

# 定义字典列表
data = [
    {'name': 'Alice', 'age': 25, 'gender': 'female', 'score': 80},
    {'name': 'Bob', 'age': 30, 'gender': 'male', 'score': 90},
    {'name': 'Alice', 'age': 25, 'gender': 'female', 'score': 95},
    {'name': 'Bob', 'age': 30, 'gender': 'male', 'score': 85},
    {'name': 'Charlie', 'age': 35, 'gender': 'male', 'score': 75},
]

# 定义分组和聚合的键
keys = ['name', 'age', 'gender']

# 定义一个defaultdict来存储分组和聚合的结果
result = defaultdict(list)

# 按照多个键进行分组
for d in data:
    group_key = tuple(d[key] for key in keys)
    result[group_key].append(d)

# 对每个分组进行聚合
for group_key, group_data in result.items():
    # 计算平均分数
    total_score = sum(d['score'] for d in group_data)
    average_score = total_score / len(group_data)
    
    # 打印结果
    print(f"Group: {group_key}, Average Score: {average_score}")
    for d in group_data:
        print(d)
    print()

这段代码首先定义了一个字典列表 data,包含了一些学生的信息。然后定义了要按照哪些键进行分组和聚合的 keys 列表。

接下来,使用 defaultdict 来创建一个空的字典 result,用于存储分组和聚合的结果。然后使用一个循环遍历字典列表 data,对每个字典根据 keys 列表中的键值进行分组,并将分组结果存入 result 字典中。

最后,使用另一个循环遍历 result 字典中的每个分组,计算每组学生的平均分数,并打印出来。同时,也打印出了每个分组内的学生详细信息。

相关内容

热门资讯

最新技巧“益乐绍兴辅助”本然有... 最新技巧“益乐绍兴辅助”本然有辅助开挂插件(有挂分析);无需打开直接搜索加(薇:136704302)...
透视智能ai“福建天天开心一直... 透视智能ai“福建天天开心一直输怎么办”原本有辅助开挂脚本(讲解有挂);无需打开直接搜索薇:1367...
实测发现“789大菠萝插件功能... 实测发现“789大菠萝插件功能”原先有开挂辅助神器(真是有挂)1、下载安装好789大菠萝插件功能,进...
一分钟揭秘“广东雀神智能插件价... 一分钟揭秘“广东雀神智能插件价格”从来有开挂辅助安装(有挂攻略);亲,广东雀神智能插件价格这款游戏原...
推荐攻略“都莱大菠萝怎么赢”原... 都莱大菠萝怎么赢开挂教程视频分享装挂详细步骤在当今的网络游戏中,都莱大菠萝怎么赢作为一种经典的娱乐方...
透视好友房“兴动互娱辅助设置步... 【亲,兴动互娱辅助设置步骤详解 这款游戏可以开挂的,确实是有挂的,很多玩家在这款兴动互娱辅助设置步骤...
指导大家“新蜜瓜房卡大厅辅助科... 指导大家“新蜜瓜房卡大厅辅助科技”原生有开挂辅助平台(有挂猫腻);无需打开直接搜索加薇1367043...
总算了解“宝宝浙江游戏脚本”往... 总算了解“宝宝浙江游戏脚本”往昔有开挂辅助平台(有挂教学);无需打开直接搜索薇:136704302 ...
解密关于“wepoker透视辅... wepoker透视辅助下载是一款可以让一直输的玩家,快速成为一个“必胜”的ai辅助神器,有需要的用户...
如何分辨真伪“山西扣点辅助工具... 大家好,今天小编来为大家解答山西扣点辅助工具这个问题咨询软件客服可以免费测试直接加微信(136704...