首先需要知道的是,其实并不需要写成*args
和**kwargs
。只有变量前面的*
是必须的,你也可以写成*var
和**vars
。
*args的用法
*args
和**kwargs
主要用于函数定义,你可以将不定数量的参数传递给一个函数。
这里的不定的意思是:预先并不知道函数的调用者会传递多少个参数,*args
是用来发送一个非键值对的可变数量的参数列表给函数。
**kwargs的用法
**kwargs
允许你将补丁长度的键值对作为参数传递给一个函数。如果你想要在一个函数里处理带名字的参数,你应该使用**kwargs
。
例子
def test_kwargs(first, *args, **kwargs):
print('Required argument: ', first)
print(type(kwargs))
for v in args:
print ('Optional argument (args): ', v)
for k, v in kwargs.items():
print ('Optional argument %s (kwargs): %s' % (k, v))
test_kwargs(1, 2, 3, 4, k1=5, k2=6)
代码的输出为:
Required argument: 1
<class 'dict'>
Optional argument (args): 2
Optional argument (args): 3
Optional argument (args): 4
Optional argument k2 (kwargs): 6
Optional argument k1 (kwargs): 5
args类型是tuple,而kwargs是dict,并且args只能位于前边
调用函数
*args
和kwargs
不仅可以在函数定义时使用,也可以在函数调用时使用。在调用时使用就相当于pack和unpack
def test_args_kwargs(arg1, arg2, arg3):
print("arg1:", arg1)
print("arg2:", arg2)
print("arg3:", arg3)
args = ("two", 3, 5)
test_args_kwargs(*args)
#result:
arg1: two
arg2: 3
arg3: 5
kwargs = {"arg3": 3, "arg2": "two", "arg1": 5}
test_args_kwargs(**kwargs)
#result
arg1: 5
arg2: two
arg3: 3