我看过this question,但我还是不明白为什么这个简单的例子不起作用:
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求值?
发布于 2016-07-16 09:53:34
lambda表达式主体中的y只是一个名称,与用于迭代mylist的y无关。作为一个自由变量,直到您实际调用该函数时才会找到y的值,此时它使用调用范围内的y的任何值。
要实际强制y在定义时具有值,您需要通过参数将其设置为主体的本地值:
dict((y, lambda x, y=z: x == str(y)) for z in mylist)发布于 2016-07-16 09:53:43
((y, lambda x: x==str(y)) for y 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}在迭代mylist时对y进行求值。
https://stackoverflow.com/questions/38406937
复制相似问题