我有一份清单清单:
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])]