我有一个配对列表,每秒不断更新新值。如果每个元组中的第二个值等于每个元组中的第一个值,我需要对它们进行求和。我尝试过使用字典,但由于键是唯一的,它会覆盖以前的更新。
[(3.05, 0.0), (3.1, 863.62), (3.05, 156.74)]
[(3.05, 0.0), (3.1, 863.62), (3.05, 156.74), (3.1, 293.97)]
[(3.05, 0.0), (3.1, 863.62), (3.05, 156.74), (3.1, 293.97), (3.05, 16.32)]
[(3.05, 0.0), (3.1, 863.62), (3.05, 156.74), (3.1, 293.97), (3.05, 16.32), (3.05, 210.72)]
期望的输出:
[(3.05, 383.06), (3.1, 1157.59)]
我不得不重现这个问题,在原来的帖子中,数字每秒从 Excel 流入。当我使用字典时,新的更新键将替换旧的键,并根据唯一键记录新值。因此,很难将所有值与它们的键相加。这只是一个示例,更新将是 excel 提供的任何内容。
import collections ,random, string
alpha = list(string.ascii_letters)
lst_a = []
lst_b = []
for i in range(100):
lst_a.append(alpha[random.choice(range(25))])
lst_b.append(random.choice(range(1000)))
combine = dict(zip(lst_a,lst_b))
print(combine.get('a'))
update = list(zip(['a'],[2000]))
combine.update(update)
print(combine.get('a'))
例如,使用键“a”,这些值不是彼此之和。
aluckdog
相关分类