我想比较 2 个迭代并打印出现在两个迭代中的项目。
>>> a = ('q', 'r')
>>> b = ('q')
# Iterate over a. If y not in b, print y.
# I want to see ['r'] printed.
>>> print([ y if y not in b for y in a])
^
但它给了我一个无效的语法错误^
。这个lamba函数有什么问题?
我想比较 2 个迭代并打印出现在两个迭代中的项目。
>>> a = ('q', 'r')
>>> b = ('q')
# Iterate over a. If y not in b, print y.
# I want to see ['r'] printed.
>>> print([ y if y not in b for y in a])
^
但它给了我一个无效的语法错误^
。这个lamba函数有什么问题?
你把顺序弄错了。if
应该在之后(for
除非它在if-else
三元运算符中)
[y for y in a if y not in b]
但是,这将起作用:
[y if y not in b else other_value for y in a]
你把它if
放在最后:
[y for y in a if y not in b]
列表推导的编写顺序与其嵌套的完整指定对应项的顺序相同,基本上上述语句转换为:
outputlist = []
for y in a:
if y not in b:
outputlist.append(y)
您的版本尝试这样做:
outputlist = []
if y not in b:
for y in a:
outputlist.append(y)
但是列表推导必须至少从一个外循环开始。
列表理解公式:
[<value_when_condition_true> if <condition> else <value_when_condition_false> for value in list_name]
因此你可以这样做:
[y for y in a if y not in b]
仅用于演示目的:[y if y not in b else False for y in a]
这不是 lambda 函数。这是一个列表理解。
只需更改顺序:
[ y for y in a if y not in b]
如果您使用足够大not in b
的列表子句,将对a
. 为什么不使用集合?Set 以 iterable 作为参数来创建一个新的 set 对象。
>>> a = ["a", "b", "c", "d", "e"]
>>> b = ["c", "d", "f", "g"]
>>> set(a).intersection(set(b))
{'c', 'd'}