Evr*_*iki 3 python list python-3.x
我有以下清单
list1 = [[x1,1,b1],[x2,1,b1],[x3,1,b1],[x4,1,b1]]
Run Code Online (Sandbox Code Playgroud)
和以下
list2 = [[x1,0,b1],[x5,0,b1],[x2,0,b1],[x7,0,b1]]
Run Code Online (Sandbox Code Playgroud)
我不知道如何创建最终列表,例如
list3 = [[x1,1,b1],[x2,1,b1],[x3,1,b1],[x4,1,b1],[x5,0,b1],[x7,0,b1]]
Run Code Online (Sandbox Code Playgroud)
仅当list1中不存在list2 [0] [0]元素时,才保留第一个list1并从list2添加到list1元素
我尝试了以下几种组合方式
for i in list1:
for i2 in list2:
if i[0][0] != i2[0][0]
list3.append(i2)
Run Code Online (Sandbox Code Playgroud)
但是list3显示常见的元素
您尝试的逻辑是错误的。因为两个组合列表中的所有元素循环时,不同的测试你的双回路故障有在某些时候是正确的。
让我提出一个更快且可行的替代方案:
list1子列表中的第一个元素以set进行快速匹配。list1和的过滤元素来创建新列表list2像这样:
list1 = [['x1',1,'b1'],['x2',1,'b1'],['x3',1,'b1'],['x4',1,'b1']]
list2 = [['x1',0,'b1'],['x5',0,'b1'],['x2',0,'b1'],['x7',0,'b1']]
list_items = {l[0] for l in list1}
list3 = list1 + [l for l in list2 if l[0] not in list_items]
Run Code Online (Sandbox Code Playgroud)
结果:
>>> list3
[['x1', 1, 'b1'],
['x2', 1, 'b1'],
['x3', 1, 'b1'],
['x4', 1, 'b1'],
['x5', 0, 'b1'],
['x7', 0, 'b1']]
Run Code Online (Sandbox Code Playgroud)