如何比较列表中的元组中的字符串

查理

我有这个元组列表[(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)

这是如何运作的?

  1. 首先定义一个dict object以累积每个名称的金额。

     summed = {}
    
  2. 逐步完成每对金额和名称:

     for amount, name in data:
    
  3. 使用该dict属性,对相同哈希进行哈希处理的结果将在dict的同一插槽中终止,并使用以下dict方法:setdefault()确保dict对我们遇到的每个名称都有一个空列表,为每个名称创建金额列表:

     summed.setdefault(name, []).append(amount)
    

    这将创建列表的字典,例如:

     {'Charlie': [214.05, 213.88], 'Ben': [153.57]}
    
  4. 最后,使用acomprehension可以sum()将所有具有相同名称的项目设置为up。

     summed = [(sum(amounts), name) for name, amounts in summed.items()]
    

结果:

[(427.93, 'Charlie'), (153.57, 'Ben')]

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章