一 简介
*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] https://eastlakeside.gitbooks.io/interpy-zh/content/args_kwargs/Using_args_and_kwargs_to_call_function.html
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/22664653/viewspace-2142139/,如需转载,请注明出处,否则将追究法律责任。