因此,Python函数可以返回多个值。令我感到震惊的是,如果可能的话,这将是方便的(尽管可读性稍差)。
a = [[1,2],[3,4]]
def cord():
return 1, 1
def printa(y,x):
print a[y][x]
printa(cord())
......但事实并非如此。我知道你可以通过将两个返回值转储到临时变量中来做同样的事情,但它看起来并不优雅。我还可以将最后一行重写为“printa(cord()[0],cord()[1])”,但这会执行两次cord()。
有一种优雅,有效的方法吗?或者我应该只看到关于过早优化的引用并忘掉这个?
答案 0 :(得分:23)
printa(*cord())
*
这里是一个参数扩展运算符......我忘了它在技术上被称为什么,但在这个上下文中它需要一个列表或元组并将其展开,以便函数将每个列表/元组元素视为一个单独的论点。
它基本上与你可能用来捕获函数定义中所有非关键字参数的*
相反:
def fn(*args):
# args is now a tuple of the non-keyworded arguments
print args
fn(1, 2, 3, 4, 5)
打印(1, 2, 3, 4, 5)
fn(*[1, 2, 3, 4, 5])
也一样。
答案 1 :(得分:6)
试试这个:
>>> def cord():
... return (1, 1)
...
>>> def printa(y, x):
... print a[y][x]
...
>>> a=[[1,2],[3,4]]
>>> printa(*cord())
4
明星基本上说“使用这个集合的元素作为位置参数。”您可以使用两个星形的关键字参数的dict执行相同的操作:
>>> a = {'a' : 2, 'b' : 3}
>>> def foo(a, b):
... print a, b
...
>>> foo(**a)
2 3
答案 2 :(得分:4)
实际上,Python并没有真正返回多个值,它返回一个值,可以将多个值打包到元组中。这意味着您需要“解包”返回的值才能获得倍数。 像
这样的陈述x,y = cord()
这样做,但直接使用返回值,如
中所做的那样printa(cord())
没有,这就是你需要使用星号的原因。也许一个很好的术语可能是“隐式元组解包”或“没有赋值的元组解包”。