我正在使用 python 3,我需要检查不同列表中的 3 个变量。如果 username
age
lang
与其他列表不同,我想打印数据
这是我的代码:
list1 = []
list2 = []
list1.append({'username' : 'alice', 'age' : 25, 'lang' : 'IT'})
list1.append({'username' : 'carole', 'age' : 40, 'lang' : 'FR'})
list1.append({'username' : 'john', 'age' : 30, 'lang' : 'FR'})
list1.append({'username' : 'mick', 'age' : 20, 'lang' : 'US'})
list1.append({'username' : 'mick', 'age' : 30, 'lang' : 'US'})
list2.append({'username' : 'mick-c', 'age' : 30, 'lang' : 'US'})
list2.append({'username' : 'john', 'age' : 30, 'lang' : 'FR'})
list2.append({'username' : 'john-b', 'age' : 30, 'lang' : 'FR'})
for l1 in list1:
username = l1['username']
age = l1['age']
lang = l1['lang']
for l2 in list2:
if username not in l2['username'] and l2['age'] != age and l2['lang'] != lang:
print(str(username) + ' ' + str(age) + ' ' + str(lang))
输出:
alice 25 IT
alice 25 IT
alice 25 IT
carole 40 FR
mick 20 US
mick 20 US
我的预期输出是:
alice 25 IT
carole 40 FR
mick 20 US
如何避免循环中出现重复数据?还有另一种方法可以做我想做的事而不是使用双循环?
最佳答案
您可以使用 set
对一个列表中的一系列 tuple
元素进行哈希处理。当名称位于 list2
中时,下面的逻辑特别有效,可以采用 name-a
、name-b
等格式,并且您只需对第一部分感兴趣。
from operator import itemgetter
def field_getter(x):
i, j, k = itemgetter('username', 'age', 'lang')(x)
return i.split('-')[0], j, k
item_set = set(map(field_getter, list2))
for d in list1:
d_fields = field_getter(d)
if field_getter(d) not in item_set:
print(*d_fields)
alice 25 IT
carole 40 FR
mick 20 US
关于Python 两个列表之间的多重条件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52834594/