求教一下表达式各变量是怎么变化的,以及结果,尤其是n怎么变呢?
fun = [(lambda n : i + n) for i in range(10)]
求教一下表达式各变量是怎么变化的,以及结果,尤其是n怎么变呢?
fun = [(lambda n : i + n) for i in range(10)]
首先,感谢 @李毅 的回答,他回答的很好。
那么,我们看看这个程序的运行结果是什么?
fun = [(lambda n : i + n) for i in range(10)]
>>> fun
[<function <lambda> at 0x7f032e425668>, <function <lambda> at 0x7f032e4256e0>, <function <lambda> at 0x7f032e425758>, <function <lambda> at 0x7f032e4257d0>, <function <lambda> at 0x7f032e425848>, <function <lambda> at 0x7f032e4258c0>, <function <lambda> at 0x7f032e425938>, <function <lambda> at 0x7f032e4259b0>, <function <lambda> at 0x7f032e425a28>, <function <lambda> at 0x7f032e425aa0>]
>>> len(fun)
>>> 10
从运行的结果可以看出,fun 参数是一个以函数对象为元素的列表,列表的长度为 10。其中的长度是由步进函数 range(10) 来决定的。
我们进行往下执行。
>>> for f in fun:
... f(1)
...
10
10
10
10
10
10
10
10
10
10
结果出现了“意外”,并不是如想象中的那样,结果是相同的,没有步进。
>>> fun = [(lambda n : i + n) for i in range(2)]
>>> fun
[<function <lambda> at 0x7f032e42e050>, <function <lambda> at 0x7f032e42e140>]
>>> fun = [(lambda n : i + n) for i in range(3)] >>> fun
[<function <lambda> at 0x7f032e425668>, <function <lambda> at 0x7f032e4256e0>, <function <lambda> at 0x7f032e425758>]
>>>
从上面的执行结果,我们可以明显的看出,步进函数决定了 list 的长度,但是这个 list 比较特别的地方是列表的元素是 function 对象,而对于 function 来说,就涉及到参数的作用域问题,而 function 对象里的 i 参数,明显是一个全局变量,@Jasoney 说的很好,这个 i 参数随着步进函数 range(10) 的迭代,不断变化,最终确定值为 9 ,那么 function 对象最终可以确定为 lambad n: 9 + n
,所以,最终的执行结果虽然“奇怪”,但也合乎逻辑。
lambda函数是里面的i是一个全局变量i,但是由于lambda函数里面所有的值只有在运行时确定。也就是当我们:
[(lambda n : i + n) for i in range(10)][1](10)
lambda里面的i已经迭代到 9,所以就变成了如fun列表就变成了如下:
[lambda n: 9 + n,
lambda n: 9 + n,
lambda n: 9 + n,
lambda n: 9 + n,
lambda n: 9 + n,
lambda n: 9 + n,
lambda n: 9 + n,
lambda n: 9 + n,
lambda n: 9 + n]
# fun = [(lambda n : i + n) for i in range(10)] 等价为
funs = []
tmp = 0
fun = lambda n: tmp + n
for i in range(10):
funs.append(fun)
tmp = i
4 回答4.4k 阅读✓ 已解决
4 回答3.8k 阅读✓ 已解决
1 回答2.9k 阅读✓ 已解决
3 回答2.1k 阅读✓ 已解决
1 回答4.5k 阅读✓ 已解决
1 回答3.8k 阅读✓ 已解决
1 回答2.8k 阅读✓ 已解决
这是 python 中为数不多的“怪事”之一
因为 lambda 内的参数 i 在运行时才能确定,不是在声明时确定。
最后 fun 保存了含有 10 个元素的数组,每一个元素都是 lambda 方法,该方法等于下面的 lambda_item 函数
如果整个表达式用 python 代码来诠释的话,可以是这样
另一个让新人迷惑的是
打印出