在函数调用中
*t
意思是“将此可迭代的元素视为此函数调用的位置参数”。
def foo(x, y):
print(x, y)
>>> t = (1, 2)
>>> foo(*t)
1 2
从 v3.5 开始,您还可以在列表/元组/集合文字中执行此操作:
>>> [1, *(2, 3), 4]
[1, 2, 3, 4]
**d
表示“将字典中的键值对视为此函数调用的附加命名参数”。
def foo(x, y):
print(x, y)
>>> d = {'x':1, 'y':2}
>>> foo(**d)
1 2
从 v3.5 开始,您还可以在字典文本中执行此操作:
>>> d = {'a': 1}
>>> {'b': 2, **d}
{'b': 2, 'a': 1}
在函数签名中
*t
意思是“获取此函数的所有附加位置参数,并将它们作为元组打包到此参数中。”
def foo(*t):
print(t)
>>> foo(1, 2)
(1, 2)
**d
意思是“将所有附加的命名参数添加到该函数中,并将它们作为字典条目插入到该参数中。”
def foo(**d):
print(d)
>>> foo(x=1, y=2)
{'y': 2, 'x': 1}
在作业和for
loops
*x
意味着“消耗右侧的附加元素”,但它不一定是最后一项。注意x
永远是一个列表:
>>> x, *xs = (1, 2, 3, 4)
>>> x
1
>>> xs
[2, 3, 4]
>>> *xs, x = (1, 2, 3, 4)
>>> xs
[1, 2, 3]
>>> x
4
>>> x, *xs, y = (1, 2, 3, 4)
>>> x
1
>>> xs
[2, 3]
>>> y
4
>>> for (x, *y, z) in [ (1, 2, 3, 4) ]: print(x, y, z)
...
1 [2, 3] 4
请注意,出现在带星号的参数(标记为*
) 仅限关键字:
def f(a, *, b): ...
f(1, b=2) # fine
f(1, 2) # error: b is keyword-only
添加了Python3.8仅位置参数 https://docs.python.org/3/whatsnew/3.8.html#positional-only-parameters,表示不能用作关键字参数的参数。他们出现在一个/
(双关语*
前面的仅关键字参数)。
def f(a, /, p, *, k): ...
f( 1, 2, k=3) # fine
f( 1, p=2, k=3) # fine
f(a=1, p=2, k=3) # error: a is positional-only