将一个嵌套列表的元素与另一个嵌套列表进行比较

时间:2017-12-21 15:26:42

标签: python list

我有两个列表列表

l1 = [[1,2,3],[4,5,6],[7,8,9]]
l2 = [['a','b',4],['c','d',1],['e','f',12],['i','j',18]]

我想迭代l1并检查l1[0]是否与任何 l2[2]匹配,在这种情况下,输出应为[1, l1[0],l2[0]]否则输出为[0, l1[0], l2[0]]。输出应该是单个嵌套列表(或元组列表),其中包含l1的每个元素的结果。两个列表都可以有不同的大小。

我尝试使用for循环来解决这个问题:

output = list()
for i in l1:
   matched = 0
   for j in l2:
       if j[2] == i[0]:
          output.append([1,i[0], j[0]])
          matched = 1
    if matched == 0:
       output.append([0,i[0]])

这样可以提供正确的输出

[[1, 1, 'c'], [1, 4, 'a'], [0, 7]]

但我正在寻找更紧凑的解决方案。是否有可能通过列表理解类似的东西来解决这个问题,这可以减少所涉及的行数?

我尝试了嵌套列表理解,但无法使其正常工作

out = [[(1,i[0],k[0]) if(k[2] == i[0]) else (0,i[0],k[0]) for k in l2] for i in l1]
print(out)
[[(0, 1, 'a'), (1, 1, 'c'), (0, 1, 'e'), (0, 1, 'i')], [(1, 4, 'a'), (0, 4, 'c'), (0, 4, 'e'), (0, 4, 'i')], [(0, 7, 'a'), (0, 7, 'c'), (0, 7, 'e'), (0, 7, 'i')]]

2 个答案:

答案 0 :(得分:4)

您好像没有使用所有元素。但是,我要从l2构建一个字典以便快速查找&简洁(单线可能是可能的,但以牺牲可读性和性能为代价)

我按照列表理解进行操作,包括根据是否找到项目而发出2或3个元素的三元组(因此不需要花哨int(if a in l2d),因为我们可以直接发出0或1 )。像这样:

l1 = [[1,2,3],[4,5,6],[7,8,9]]
l2 = [['a','b',4],['c','d',1],['e','f',12],['i','j',18]]

l2d = {v[2]:v[0] for v in l2}  # not using v[1]

result = [[1,a,l2d[a]] if a in l2d else [0,a] for a,_,_ in l1]  # using only first element of each l1 triplet...

结果:

[[1, 1, 'c'], [1, 4, 'a'], [0, 7]]

(请注意,携带其他未使用的物品并不能真正帮助理解问题)

答案 1 :(得分:1)

更好地建立字典以加快搜索速度。

d = { c: a for [a,b,c] in l2 }

现在你可以使用它:

[[int(a in d), a] + ([d[a]] if a in d else [])
 for a,b,c in l1]

返回

[[1, 1, 'c'], [1, 4, 'a'], [0, 7]]