python中的lambda列表
我已经看到了,但我仍然不明白为什么这样简单的例子不起作用:python中的lambda列表,python,list,lambda,Python,List,Lambda,我已经看到了,但我仍然不明白为什么这样简单的例子不起作用: mylist = ["alice", "bob", "greta"] funcdict = dict(((y, lambda x: x==str(y)) for y in mylist)) funcdict['alice']("greta") #True funcdict['alice']("alice") #False funcdict['greta']("greta") #True 它与: [(y, y) for y in myl
mylist = ["alice", "bob", "greta"]
funcdict = dict(((y, lambda x: x==str(y)) for y in mylist))
funcdict['alice']("greta")
#True
funcdict['alice']("alice")
#False
funcdict['greta']("greta")
#True
它与:
[(y, y) for y in mylist]
为什么
y
不在迭代的每个步骤中求值?lambda表达式主体中的y
只是一个名称,与用于迭代mylist
的y
无关。作为一个自由变量,y
的值在您实际调用函数之前是找不到的,此时它使用调用范围内的y
的任何值
要实际强制y
在定义时具有一个值,需要通过参数将其设置为主体的局部值:
dict((y, lambda x, y=z: x == str(y)) for z in mylist)
在定义生成表达式时,lambda中的y
未绑定,但在调用时已绑定;调用时,迭代已经完成,因此y
引用最后一项greta
解决此问题的一种方法是使用关键字参数,该参数在定义函数/lambda时计算:
funcdict = dict((y, lambda x, y=y: x == y) for y in mylist)
funcdict = {y: lambda x, y=y: x == y for y in mylist} # dict-comprehension
或者您可以使用partial
:
funcdict = {y: partial(operator.eq, y) for y in mylist}
y
在迭代mylist
时进行求值。为什么要求值y
:它是列表中的临时变量。
funcdict = {y: partial(operator.eq, y) for y in mylist}