一 简介
*args 和 **kwargs 主要用于函数定义。 当我们需要定义的函数的传入参数个数不确定时,可以使用*args 和 **kwargs 代替不确定的参数个数。其实并不是必须写成*args 和**kwargs。 只有变量前面的 *(星号)才是必须的. 我们可以写成*var和**vars. 而写成*args 和**kwargs只是一个通俗的命名约定。
二 使用
2.1 *args
当函数的参数个数不确定且不需要指定参数名称时,*args的格式是常规的参数 val1[,val2,val3....]
-
def func_arg(farg, *args):
-
print "formal arg:", farg
-
for arg in args:
-
print "another arg:", arg
-
func_arg(1,"youzan",'dba')
-
输出
-
In [10]: args(1,"youzan",'dba')
-
formal arg: 1
-
another arg: youzan
-
another arg: dba
2.2 **kwargs
当函数的参数是有名称且不确定个数的时候,可以使用**kwargs。**kwargs的参数格式是 key1=value1,[key2=value2,key3=value3,....],函数对**kwargs是以键值对类似字典的方式进行解析。
-
def func_kwargs(farg, **kwargs):
-
print "formal arg:", farg
-
for key in kwargs:
-
print "keyword arg: %s: %s" % (key, kwargs[key])
-
输出
-
In [15]: func_kwargs(1 ,id=1, name='youzan', city='hangzhou')
-
formal arg: 1
-
keyword arg: city: hangzhou
-
keyword arg: id: 1
-
keyword arg: name: youzan
**kwargs还有一个功能就是转换参数为字典
-
In [1]: def kw_dict(**kwargs):
-
...: return kwargs
-
...:
-
In [2]: print kw_dict(a=1,b=2,c=3)
-
{'a': 1, 'c': 3, 'b': 2}
2.3 综合的例子
-
In [3]: def foo(*args, **kwargs):
-
...: print 'args = ', args
-
...: print 'kwargs = ', kwargs
-
...: print '---------------------------------------'
-
...:
-
In [4]: foo(1,2,3,4)
-
args = (1, 2, 3, 4)
-
kwargs = {}
-
---------------------------------------
-
In [5]: foo(a=1,b=2,c=3)
-
args = ()
-
kwargs = {'a': 1, 'c': 3, 'b': 2}
-
---------------------------------------
-
In [6]: foo(1,2,3,4, a=1,b=2,c=3)
-
args = (1, 2, 3, 4)
-
kwargs = {'a': 1, 'c': 3, 'b': 2}
-
---------------------------------------
-
In [7]: foo('a', 1, None, a=1, b='2', c=3)
-
args = ('a', 1, None)
-
kwargs = {'a': 1, 'c': 3, 'b': '2'}
-
---------------------------------------
2.4 使用顺序
标准参数与*args、**kwargs在使用时的顺序,当我们想在函数里同时使用所有这三种参数, 顺序是这样的:
func(fargs, *args, **kwargs)
三 参考文档
[1]
how-to-use-args-and-kwargs-in-python
[2] https://eastlakeside.gitbooks.io/interpy-zh/content/args_kwargs/Using_args_and_kwargs_to_call_function.html