lambda不能有2+的返回值?

时间:2012-10-07 09:21:25

标签: python lambda

>>> def itself_and_plusone(x):
...     return x, x+1
... 
>>> itself_and_plusone(1)
(1, 2)

>>> (lambda x: x,x+1)(10)
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
NameError: name 'x' is not defined

为什么呢?和lambda一起解决?

>>> (lambda x: (x,x+1))(10)
(10, 11)

因为它返回一个元组(或列表..)并且需要解包元组

2 个答案:

答案 0 :(得分:12)

如果没有括号,则解释如下:

((lambda x: x),x+1)(10)

这会失败,因为第二个x在lambda表达式之外。即使定义了x,它仍然会失败,因为你不能像使用函数那样使用元组。

这个简单的变体显示了正在发生的事情:

>>> x=42
>>> (lambda x: x,x+1)
(<function <lambda> at 0x00000000022B2648>, 43)

请注意,43是因为使用了外部作用域中的x,而不是lambda函数中的x

编写它的正确方法是lambda x: (x,x+1)。确实如此,正如你所指出的那样,返回一个元组,但你的原始功能也是如此:

>>> type(itself_and_plusone(10))
<class 'tuple'>

答案 1 :(得分:1)

在你的第一个例子中,元组是隐含的; python在看到表达式中的逗号时为你想象括号;它为任何表达式执行此操作,而不仅仅是从函数返回时:

>>> 10, 10
(10, 10)

但是在你的lambda例子中,你必须使它们显式化,因为python将整个表达式视为一个新的元组(包含一个lambda和一个x + 1表达式):

>>> (lambda x: x, 10)
(<function <lambda> at 0x10f331b90>, 10)
>>> lambda x: x, 10
(<function <lambda> at 0x10f331aa0>, 10)
>>> lambda x: (10, 10)
<function <lambda> at 0x10f314ed8>