*args
-
*args是为了传入任意不定数量的参数
-
所有的不定参数都在args里面,形成一个tuple传入函数内部
-
*args一般用在关键字参数后面
def func(a,*args): print(type(args)) print(args) print(a) >>>func(1) <class 'tuple'> () 1 >>>func(10,2,'a') <class 'tuple'> (2, 'a') 10 >>>func(1,2,m=3) Traceback (most recent call last): File "<input>", line 1, in <module> TypeError: func() got an unexpected keyword argument 'm'
*args参数不能接收关键字,只需要直接传参数值。接收关键字的是后续的**kwargs
**kwargs
-
**kwargs是为了传入任意不定数量的关键字参数
-
最后传入的不定数量的关键字参数都在kwargs里面,形成一个dict传入函数
-
**kwargs只能放在函数最后一个参数。
-
函数参数的一般顺序是:关键字参数,*args,**kwargs
def func(x,y,*t,**test): print(type(test)) print(test.keys()) print(test.values()) res1=sum(t) res2=sum(test.values()) print('res1:%s'%(res1)) print('res2:%s'%(res2)) return res1,res2 >>>func(1,2,10,20,m=100,n=200) <class 'dict'> dict_keys(['m', 'n']) dict_values([100, 200]) res1:30 res2:300 >>>func(1,2,10,20,30,m=100,n=200,k=-100,g=-200) <class 'dict'> dict_keys(['m', 'n', 'k', 'g']) dict_values([100, 200, -100, -200]) res1:60 res2:0
使用场景
一个很有用的使用场景(在一个函数内部调用另一个函数):
定义一个函数func,实现某种功能(比如求两数之和)。而项目有特殊要求,需要对结果进行各种检验(类型检验,大小检验等等),需要对结果调用check_data()函数。如代码所示:
import check_data def func(x,y,*args,**kwargs): data=x+y is_valid=check_data(*args,**kwargs) if is_valid: return data else: raise Exception('data is not valid')
这种时候,x和y是关键字参数,主要用在函数内部进行相应功能的实现。而*args和**kwargs则是不定参数,但这里专门用来传入check_data中。
这样做的好处:如果check_data里面有很多参数需要传递,大部分是使用默认值,这个时候如果在func()函数里都写出来会非常冗余,使用函数非常不清晰。通过这种方式,可以在使用时将参数重点放在关键字参数上,而若对check_data函数有特殊设置,再对有特殊设置的参数通过*args和**kwargs传进去。灵活且简洁。
这种使用方式需要注意的是*args或者**kwargs只用在一个函数或类上。用于多个极易混淆出错。