我有两个列表列表
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')]]
答案 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]]