仅位置参数(Positional-Only Arguments)
这是Python3.8新特性的第二篇,第一篇介绍了赋值表达式,这篇文章花几分钟了解什么是仅位置参数(Positional-Only Arguments)
函数传递参数的方式繁多,有位置参数、默认参数、可变参数、关键字参数、命名关键字参数。举个例子:
def add(x, y, *args, **kwargs):
print(f"x={x}, y={y}")
这里的 x 和 y 就是两个位置参数,我们可以这样调用
>>> add(1, 2)
x=1, y=2
因为是位置参数,严格遵守位置顺序。
不过,你也可以把 x 和 y 当做命名关键字参数进行传递,参数的顺序可改变,例如把 y 放前面,不影响结果
>>> add(y=2, x=1)
x=1, y=2
第二种方式看似更灵活,出错的风险也增加了,特别是多人合作的项目中,例如后期如果有人将该函数的参数名字修改后,调用该函数就报错了。
那么如何从语法层面上禁止这样调用,避免出错呢?
这里就可以使用Python3.8中的仅位置参数语法了,在函数定义时,参数之间可指定一个斜杠(/),斜杠前的参数严格遵守仅位置参数的定义,例如:
>>> def add(x, y, /, *args, **kwargs):
... print(f"x={x}, y={y}")
...
>>> add(1,2)
x=1, y=2
"/" 告诉解释器,x 和 y 是两个严格的位置参数,不能当做命名关键字参数进行传递。如果把它当作命名关键字参数进行传递参数时,会怎么样呢?
>>> add(y=2, x=1)
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
TypeError: add() missing 2 required positional arguments: 'x' and 'y'
报错了,系统不允许你使用这种方式调用,仅支持位置参数的方式进行调用,调用时不能指定参数的名字。
其实,这个语法在Python3.7 就有出现过,比如内置函数 float
python3.6可以指定参数名字进行调用
>>> float(x=1)
1.0
python3.7就会报错
>>> float(x=1)
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
TypeError: float() takes no keyword arguments
>>> float(1)
1.0
可以看下python3.7 下 float 的帮助文档
>>> help(float)
Help on class float in module builtins:
class float(object)
| float(x=0, /)
|
| Convert a string or number to a floating point number, if possible.
|
| Methods defined here:
|
| __abs__(self, /)
| abs(self)
你会发现float定义中,也有个 "/",说明 x 是位置参数,调用时,不能指定名字。
总结
仅位置参数的语法就是在函数定义时,位置参数用 “/” 进行分隔,调用时不允许使用命名关键字参数进行调用,你明白了吗?
关注公众号「Python之禅」,回复「1024」免费获取Python资源