我想将一个列表中的值与第二个列表中的值进行比较,并返回第一个列表中但不在第二个列表中的所有值,即
。list1 = ['one','two','three','four','five']
list2 = ['one','two','four']
将返回'三'和'五'。
我对python只有一点经验,所以这可能会成为一种荒谬而愚蠢的尝试解决方法,但这就是我迄今所做的:
def unusedCategories(self):
unused = []
for category in self.catList:
if category != used in self.usedList:
unused.append(category)
return unused
然而,这会引发错误'迭代超过非序列',我认为这意味着一个或两个'列表'实际上不是列表(两者的原始输出与我的第一个示例的格式相同)< / p>
答案 0 :(得分:8)
set(list1).difference(set(list2))
答案 1 :(得分:6)
使用集合来获取列表之间的差异:
>>> list1 = ['one','two','three','four','five']
>>> list2 = ['one','two','four']
>>> set(list1) - set(list2)
set(['five', 'three'])
答案 2 :(得分:1)
>>> list1 = ['one','two','three','four','five']
>>> list2 = ['one','two','four']
>>> set(list1).difference(list2)
{'five', 'three'}
您可以跳过将list2
转换为设置。
答案 3 :(得分:0)
您可以使用集合或列表理解来实现:
unused = [i for i in list1 if i not in list2]
答案 4 :(得分:0)
这里的所有答案都是正确的。如果列表很短,我会使用列表理解;套装会更有效率。在探索为什么你的代码不起作用时,我没有得到错误。 (它不起作用,但这是一个不同的问题)。
>>> list1 = ['a','b','c']
>>> list2 = ['a','b','d']
>>> [c for c in list1 if not c in list2]
['c']
>>> set(list1).difference(set(list2))
set(['c'])
>>> L = list()
>>> for c in list1:
... if c != L in list2:
... L.append(c)
...
>>> L
[]
问题是if
语句毫无意义。
希望这会有所帮助。