Python中是否有一种方法可以在调用函数时将可选参数传递给函数,并且在函数定义中有一些代码基于“只有传递了可选参数”
答案 0 :(得分:109)
Python 2 documentation, 7.6. Function definitions为您提供了几种方法来检测调用者是否提供了可选参数。
首先,您可以使用特殊的形式参数语法*
。如果函数定义的前缀为*
的形式参数,那么Python会使用前面的形式参数(作为元组)不匹配的任何位置参数填充该参数。如果函数定义的前缀为**
的形式参数,则Python使用任何与前面的形式参数(作为dict)不匹配的关键字参数填充该参数。函数的实现可以检查这些参数的内容,以查找所需类型的任何“可选参数”。
例如,这是一个函数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
。如果参数具有此默认值,则表示调用者未指定参数。如果参数具有非默认值,则表示它来自调用者。
答案 1 :(得分:74)
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:
...
答案 2 :(得分:20)
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.
答案 3 :(得分:7)
如果要为()中的参数赋值赋予一些默认值。喜欢(x = 10)。但重要的是首先应该强制参数然后默认值。
例如。
(y,x = 10)
但是
(x = 10,y)错误
答案 4 :(得分:2)
您可以使用永远不会传递给函数的内容为可选参数指定默认值,并使用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)
,你就可以准确地检测出论证是否通过了,并且与接受的答案不同,你不必担心**符号的副作用: / p>
# 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)