我有一个列表列表:
['test', 'testlink', 1]
['test', 'testlink', 2]
['test ', 'testlink', 3]
['test ', 'testlink', 4]
['test 2', 'test2link', 1]
['test 2', 'test2link', 2]
['test 3', 'test3link', 1]
['test 3', 'test3link', 3]
['test 3', 'test3link', 4]
我想过滤列表以返回每个唯一第一个元素的第三个元素的最大值。
我想要的结果是:
['test ', 'testlink', 4]
['test 2', 'test2link', 2]
['test 3', 'test3link', 4]
我正在努力寻找一种方法来做到这一点。下面的代码块进入我的排序列表,但在那之后我被卡住了。
#create some dummy data
rows=[]
rows.append(["test","testlink",1])
rows.append(["test 2","test2link",1])
rows.append(["test 3","test3link",1])
rows.append(["test","testlink",2])
rows.append(["test","testlink",1])
rows.append(["test 2","test2link",1])
rows.append(["test 3","test3link",1])
rows.append(["test ","testlink",3])
rows.append(["test 3","test3link",3])
rows.append(["test ","testlink",4])
rows.append(["test 3","test3link",4])
rows.append(["test 2","test2link",2])
#filter out duplicates
newRows = []
for elem in rows:
if elem not in newRows:
newRows.append(elem)
rows = newRows
#sort the lists
rows = sorted(rows,key=lambda x: (x[0],x[2]))
谢谢所有排序给出的答案都可以在我的 Ironpython 环境中工作
UYOU
慕妹3146593
相关分类