有没有办法将可选参数传递给函数?

时间:2012-12-24 06:41:25

标签: python

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

5 个答案:

答案 0 :(得分:109)

Python 2 documentation, 7.6. Function definitions为您提供了几种方法来检测调用者是否提供了可选参数。

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

例如,这是一个函数opt_fun,它接受​​两个位置参数x1x2,并查找另一个名为“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)