有没有办法将可选参数传递给函数?
- 2025-03-04 08:25:00
- admin 原创
- 93
问题描述:
Python 中是否有一种方法可以在调用函数时将可选参数传递给该函数,并且在函数定义中有一些基于“仅当传递可选参数时”的代码
解决方案 1:
Python 2 文档7.6.函数定义为您提供了几种方法来检测调用者是否提供了可选参数。
首先,您可以使用特殊的形式参数语法*
。如果函数定义的形式参数前面有一个*
,那么 Python 会用任何与前面的形式参数不匹配的位置参数(作为元组)填充该参数。如果函数定义的形式参数前面有一个**
,那么 Python 会用任何与前面的形式参数不匹配的关键字参数(作为字典)填充该参数。函数的实现可以检查这些参数的内容,以查找您想要的任何“可选参数”。
例如,这里有一个函数opt_fun
,它接受两个位置参数x1
和x2
,并查找另一个名为“optional”的关键字参数。
>>> def opt_fun(x1, x2, *positional_parameters, **keyword_parameters):
... if ('optional' in keyword_parameters):
... print 'optional parameter found, it is ', keyword_parameters['optional']
... else:
... print 'no optional parameter, sorry'
...
>>> opt_fun(1, 2)
no optional parameter, sorry
>>> opt_fun(1,2, optional="yes")
optional parameter found, it is yes
>>> opt_fun(1,2, another="yes")
no optional parameter, sorry
其次,您可以提供某个值的默认参数值,例如None
调用者永远不会使用的值。如果参数具有此默认值,则您知道调用者未指定该参数。如果参数具有非默认值,则您知道它来自调用者。
解决方案 2:
def my_func(mandatory_arg, optional_arg=100):
print(mandatory_arg, optional_arg)
http://docs.python.org/2/tutorial/controlflow.html#default-argument-values
我发现这比使用更具可读性**kwargs
。
为了确定参数是否被传递,我使用自定义实用程序对象作为默认值:
MISSING = object()
def func(arg=MISSING):
if arg is MISSING:
...
解决方案 3:
def op(a=4,b=6):
add = a+b
print add
i)op() [o/p: will be (4+6)=10]
ii)op(99) [o/p: will be (99+6)=105]
iii)op(1,1) [o/p: will be (1+1)=2]
Note:
If none or one parameter is passed the default passed parameter will be considered for the function.
解决方案 4:
如果要为参数指定一些默认值,请在 () 中分配值。例如 (x =10)。但重要的是首先应该是强制参数,然后是默认值。
例如。
(y,x =10)
但
(x=10, y) 错误
解决方案 5:
您可以为可选参数指定一个默认值,该默认值永远不会传递给函数,并使用is
运算符进行检查:
class _NO_DEFAULT:
def __repr__(self):return "<no default>"
_NO_DEFAULT = _NO_DEFAULT()
def func(optional= _NO_DEFAULT):
if optional is _NO_DEFAULT:
print("the optional argument was not passed")
else:
print("the optional argument was:",optional)
那么只要你不这样做,func(_NO_DEFAULT)
你就可以准确地检测出参数是否被传递,并且与接受的答案不同,你不必担心 ** 符号的副作用:
# these two work the same as using **
func()
func(optional=1)
# the optional argument can be positional or keyword unlike using **
func(1)
#this correctly raises an error where as it would need to be explicitly checked when using **
func(invalid_arg=7)
扫码咨询,免费领取项目管理大礼包!