當咱們的函數接收參數爲任意個,或者不能肯定參數個數時,咱們,能夠利用*
來定義任意數目的參數,這個函數調用時,其全部不匹配的位置參數會被賦值爲元組,咱們能夠在函數利用循環或索引進行使用python
def f(*args): # 直接打印元組參數 print(args) print('-'*20) # 循環打印元組參數 [print(i) for i in args] ... # 傳遞一個參數 f(1) print('='*20) # 傳遞5個參數 f(1, 2, 3, 4, 5) 複製代碼
示例結果:bash
(1,)
--------------------
1
====================
(1, 2, 3, 4, 5)
--------------------
1
2
3
4
5
複製代碼
###任意參數 ** 而**
是用於收集關鍵字參數並將這些參數傳遞給一個新的字典,即在函數中咱們能夠利用處理字典的方式處理這些參數markdown
def f(**args): # 直接打印字典參數 print(args) for key, value in args.items(): print('{}: {}'.format(key, value)) f(a=1) print('='*20) f(a=1, b=2, c=3) 複製代碼
示例結果:函數
{'a': 1} a: 1 ==================== {'a': 1, 'b': 2, 'c': 3} a: 1 b: 2 c: 3 複製代碼
咱們能夠混合通常參數、*
參數以及**
參數完成實現更加複雜的調用方式。spa
def f(a, *targs, **dargs): print(a, targs, dargs) f(1,2,3, x=1, y=2) 複製代碼
示例結果:code
1 (2, 3) {'x': 1, 'y': 2} 複製代碼
能夠看到這種調用方式並不那麼直觀,甚至有些「混淆視聽」,那麼怎麼在複雜任意參數的調用時,是的在函數調用更加直觀明瞭?orm
咱們能夠在函數調用時,直接利用*和**進行參數傳遞,而後讓函數自動解包,也就相似以前的序列解包,使用調用時更加的直觀。索引
def f(a, b, c, d): print(a, b, c, d) f(1, *(2, 3), **{'d': 4}) 複製代碼
示例結果:it
1 2 3 4
複製代碼