有没有一种方法可以将可选参数传递给函数?

在 Python 中有没有一种方法可以在调用函数时将可选参数传递给函数,并且在函数定义中有一些基于“只有当可选参数被传递”的代码

257827 次浏览
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:
...

如果希望为参数赋予某个默认值,请在()中赋值。例如(x = 10)。但重要的是首先应该强制参数然后默认值。

例如。

(y,x = 10)

但是

(x = 10,y)是错误的

Python 2文档,< em > 7.6. 函数定义 提供了两种方法来检测调用方是否提供了可选参数。

首先,可以使用特殊的形式参数语法 *。如果函数定义前面有一个形式参数,那么 Python 将使用任何与前面的形式参数(作为元组)不匹配的位置参数填充该参数。如果函数定义前面有一个形式参数 **,那么 Python 将使用任何与前面的形式参数不匹配的关键字参数填充该参数(作为 dict)。该函数的实现可以检查这些参数的内容,以查找所需的任何“可选参数”。

例如,这里有一个函数 opt_fun,它接受两个位置参数 x1x2,并寻找另一个名为“可选”的关键字参数。

>>> 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。如果参数具有此默认值,则可以知道调用方没有指定参数。如果参数具有非默认值,则知道它来自调用方。

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.

您可以使用一些永远不会传递给函数的内容为可选参数指定一个默认值,然后使用 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)