想要获取根据条件在指定索引上具有最大值的子列表。
mainlist=[[['RD-2', 'a', 120], ['RD-2', 'b', 125], ['RD-2', 'c', 127]], [['RD-3', 'a', 120], ['RD-3', 'b', 140]], [['RD-5', 'a', 120]],[['RD-7', 'a', 122]]]
和另一个列表
baselist=[['RD-2', 100],['RD-3', 200],['RD-5', 240]]
对于基本列表中的每个第一个子元素,我需要主列表中的1个完整的子列表,该列表在第二个索引位置具有最大值。 输出应为
flist=[['RD-2', 'c', 127],['RD-3', 'b', 140],['RD-5', 'a', 120]]
救救我。
答案 0 :(得分:3)
尝试一下:
flist = []
for item in baselist:
for i in mainlist:
if i[0][0] ==item[0]:
flist.append(max(i, key=lambda x:x[2]))
flist
将是:
[['RD-2', 'c', 127], ['RD-3', 'b', 140], ['RD-5', 'a', 120]]
您还可以使用itertools.product
简单地for
循环一下:
from itertools import product
flist = []
for i, item in product(mainlist,baselist):
if i[0][0] ==item[0]:
flist.append(max(i, key=lambda x:x[2]))
或仅一行:
flist = [max(i, key=lambda x:x[2]) for i, item in product(mainlist,baselist) if i[0][0] == item[0]]
答案 1 :(得分:2)
更紧凑,但使用列表理解具有相同的结果:
max_entries = [max(x, key=lambda x:x[2]) for x in mainlist]
flist = [max_entry for max_entry in max_entries for base_entry in baselist if max_entry[0]==base_entry[0]]
答案 2 :(得分:2)
这是一种使用列表理解的方法:
base = list(zip(*baselist))[0]
[max(i, key=lambda x:x[2]) for i in mainlist if i[0][0] in base]
[['RD-2', 'c', 127], ['RD-3', 'b', 140], ['RD-5', 'a', 120]]
答案 3 :(得分:1)
我会先将最大列表存储在字典中,然后稍后再引用该字典以构建新列表:
from operator import itemgetter
mainlist = [
[["RD-2", "a", 120], ["RD-2", "b", 125], ["RD-2", "c", 127]],
[["RD-3", "a", 120], ["RD-3", "b", 140]],
[["RD-5", "a", 120]],
[["RD-7", "a", 122]],
]
baselist = [["RD-2", 100], ["RD-3", 200], ["RD-5", 240]]
d = {}
for sublist in mainlist:
k = sublist[0][0]
d[k] = max(sublist, key=itemgetter(2))
flist = [d.get(k) for k, _ in baselist]
print(flist)
# [['RD-2', 'c', 127], ['RD-3', 'b', 140], ['RD-5', 'a', 120]]