如果元组具有相同的第一个元素,如何聚合元组列表的元素?

前端之家收集整理的这篇文章主要介绍了如果元组具有相同的第一个元素,如何聚合元组列表的元素?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我有一个列表,其中每个值是一个元组列表.例如,这是我为密钥提取的值: @H_301_1@[('1998-01-20',8),('1998-01-22',4),('1998-06-18',8 ),('1999-07-15',7),('1999-07-21',1) ]

我也对列表进行了排序.
现在我想聚合这样的值:

@H_301_1@[('1998-01',12 ),('1998-06',('1999-07',8 )]

从某种意义上说,我想按月分组我的元组,一起总结每个月的整数,我读过有关groupby的内容,我认为它对我的数据结构无法帮助,因为我不知道我会做什么面对我的列表所以我试图找到一种说法:如果i [0] [:6]相等,则从元组的第一个元素开始:sum i [1].但是我很难实现这个想法.

@H_301_1@for i in List : if i[0][:6] # *problem* I don't know how to say my condition : s=sum(i[1]) #?

我很感激任何建议,因为我是python的新用户

还有一个答案与已经给出的答案不同.您可以简单地创建一个新的字典,其中键是年 – 月组合.使用dictionary.get(key,defaultvalue)遍历列表中的日期应该可以解决问题. IT将当前值添加到新字典中的值,如果密钥尚不存在,则返回默认值0并创建密钥. @H_301_1@data = [('1998-01-20',1)] dictionary = dict() for (mydate,val) in data: # ym = mydate[0:7] # the key is only the year month combination (i.e. '1998-01' for example) dictionary[ym] = dictionary.get(ym,0) + val # return the value for that key or return default 0 (and create key) data_aggregated = [(key,val) for (key,val) in dictionary.iteritems()] # if you need it back in old format
原文链接:https://www.f2er.com/javaschema/281595.html

猜你在找的设计模式相关文章