我有这个元组列表[(amount, name)]
:
[(214.05, 'Charlie'), (153.57, 'Ben'),(213.88, 'Charlie')]
我试图通过它们的名称来比较它们,如果有一个具有相同名称的元组,我想将这些数量加在一起。
输出将进入具有相同结构的另一个列表[(amount,name)]
。
我设法提取名称部分与此:
for i in range(0, len(spendList)):
print(spendList[i][1])
输出:
Charlie
Ben
Charlie
如何将名称相互比较?
执行这些操作的一种方法是使用dict.setdefault()
类似:
data = [(214.05, 'Charlie'), (153.57, 'Ben'), (213.88, 'Charlie')]
summed = {}
for amount, name in data:
summed.setdefault(name, []).append(amount)
summed = [(sum(amounts), name) for name, amounts in summed.items()]
print(summed)
首先定义一个dict object
以累积每个名称的金额。
summed = {}
逐步完成每对金额和名称:
for amount, name in data:
使用该dict
属性,对相同哈希进行哈希处理的结果将在dict的同一插槽中终止,并使用以下dict
方法:setdefault()
确保dict对我们遇到的每个名称都有一个空列表,为每个名称创建金额列表:
summed.setdefault(name, []).append(amount)
这将创建列表的字典,例如:
{'Charlie': [214.05, 213.88], 'Ben': [153.57]}
最后,使用acomprehension
可以sum()
将所有具有相同名称的项目设置为up。
summed = [(sum(amounts), name) for name, amounts in summed.items()]
[(427.93, 'Charlie'), (153.57, 'Ben')]
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句