本文介绍如何将包含姓名与数字的二维列表按姓名去重合并,并对对应数字进行累加,推荐使用字典实现 o(n) 时间复杂度的高效聚合。
在处理类似 [['Smith, Karen', '10'], ['Miller, Michael', '20'], ...] 这样的结构化数据时,核心需求是:按姓名(第一列)分组,将所有对应数字(第二列)转换为整数后求和。直接在列表上反复查找、修改效率低下(尤其在 4000+ 条数据时),而 Python 字典天然支持键值映射与快速更新,是最简洁、高效的解决方案。
以下是推荐的实现方式:
mylist = [['Smith, Karen', '10'], ['Miller, Michael', '20'], ['Smith, Karen', '30'], ['Taylor, Peter', '95']]
# 使用字典累计数值:name → total_number
result_dict = {}
for name, num_str in mylist:
result_dict[name] = result_dict.get(name, 0) + int(num_str)
# 转回所需格式:列表嵌套列表
mylist = [[name, str(total)] for name, total in result_dict.items()]
print(mylist)
# 输出: [['Smith, Karen
', '40'], ['Miller, Michael', '20'], ['Taylor, Peter', '95']]✅ 关键优势说明:
⚠️ 注意事项:
该方法兼顾可读性、性能与健壮性,是处理此类“键值聚合”问题的标准实践。