我們通過一個簡單的事例來展示一下函式的萬能引數,我們先寫一個最簡單的函式
def test(*args,**kwargs):
print(args,kwargs)
然后定義兩個變數
l = [1,2,3,4]
d = {"a":1,"b":2}
下面我們分別看下兩種傳參的方式有什么不同
第一種方式
test(l,d)
如果是使用上面的方式傳參,那么l,d這2個變數都會傳遞給args這個形參,作為args變數的兩個元素,kwargs是一個空的字典,沒有任何引數傳遞一個他
([1, 2, 3, 4], {'a': 1, 'b': 2}) {}
我們可以看到串列l和字典d被當做一個tuple的兩個元素了
第二種方式
test(*l,**d)
如果是上面的方式傳參,那么l這個變數就會被賦值給args,d這個變數就會被賦值給kwargs
(1, 2, 3, 4) {'a': 1, 'b': 2}
通過上面的演示,你應該基本上了解python的萬能引數了吧,也知道如果函式使用萬能引數,你應該如何進行傳參了把
今天被搞糊涂了,又把萬能引數梳理一下
大家先看下這個函式
def foo(action=None,**kwargs):
print("action",action,sep="=================>")
print("kwargs", kwargs, sep="=================>")
d = {"a":1,"b":2}
foo(d)
print("=".center(100,"*"))
foo(**d)
我執行的結果如下

下面我來解釋一下
第一種呼叫函式的方式,傳遞了一個字典進去,這個字典會被當做一個整體傳遞進去,這個字典會被賦值給位置變了,也就是action
第二種呼叫函式的方法,通過**字典的方法傳遞進去,他實際是這樣傳遞的a=1,b=2這樣傳遞進去的,實際上一個命名變數,而這2個變數的名稱都不action,所以第二中呼叫的方式的結果就是
action為none
kwargs就是一個字典
我們在看來下第三種呼叫的方法
d = {"action":"action","a":1}
foo(**d)
下面在看下結果,是否就明白了一些了

轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/236937.html
標籤:Python
