gpt4 book ai didi

python - 在我的列表中查找最高版本

转载 作者:行者123 更新时间:2023-12-01 07:28:24 25 4
gpt4 key购买 nike

我有一个列表列表:

['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 环境中工作

最佳答案

您可以使用defaultdict :

from collections import defaultdict

l = [['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]]

d = defaultdict(int)
for first, second, third in l:
if d[(first, second)] < third:
d[(first, second)] = third

要以您想要的格式形成结果,请使用下一行:

res = [[*key, value] for key, value in d.items()]
<小时/>

如果您不想导入 defaultdict,您可以使用常规的:

d = {}
for first, second, third in l:
item = d.get((first, second), None)
if not item or item < third:
d[(first, second)] = third

关于python - 在我的列表中查找最高版本,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57331703/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com