加入收藏 | 设为首页 | 会员中心 | 我要投稿 甘南站长网 (https://www.0941zz.com/)- 科技、行业物联网、开发、云计算、云管理!
当前位置: 首页 > 编程开发 > Python > 正文

python – Groupby列表中的多个列

发布时间:2020-09-16 07:08:43 所属栏目:Python 来源:互联网
导读:我有一个列表,如下所示 [[H1,L, 1][H1,S, 1][H2,L, 1][H2,L, 1]] 并希望基于column1和column2进行分组. python是否在列表中提供了我可以获得以下结果的任何内容 H1 L 1H1 S 1H2 L 2 您可以使用 itertools.groupby,并将每个组的最后一列相加. from it

我有一个列表,如下所示

[['H1','L','1']
['H1','S','1']
['H2','1']]

并希望基于column1和column2进行分组. python是否在列表中提供了我可以获得以下结果的任何内容

H1 L 1
H1 S 1
H2 L 2

解决方法

您可以使用 itertools.groupby,并将每个组的最后一列相加.
from itertools import groupby

out = []
for k,v in groupby(l,key=lambda x: x[:2]):
    s = sum([int(x[-1]) for x in v])
    out.append(k + [s])

print (out)
# [['H1',1],['H1',['H2',2]]

(编辑:甘南站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读