Python – 比较列表列表并选择最大值

我有一份清单清单:

l = [['a1', 2], ['a1', 3], ['a1', 1], ['b1', 4], ['b1', 2], ['b1', 6], ['c1', 2]]

我想将每个“子列表”与其他“子列表”进行比较,匹配索引[0]具有相同值的那些,并保留那些具有最大索引[1]的那些,以便结果是这样的:

resultingList = [['a1', 3], ['b1', 6], ['c1', 2]]

我一直在尝试各种for循环和条件语句,但我已经陷入困境.

有人能帮我一把,让我走上正轨吗?

最佳答案 使用
itertools.groupby

from itertools import groupby
l=[['a1',2],['a1',3],['a1',1],['b1',4],['b1',2],['b1',6],['c1',2]]
l = [max(g, key=lambda x: x[1]) for k, g in groupby(sorted(l), key=lambda x: x[0])]
点赞