一 简介
*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
时间: 2024-09-30 10:19:09