python 函式引數的傳遞(引數帶星號的說明)

G8bao7發表於2015-10-26
from: http://www.cnblogs.com/smiler/archive/2010/08/02/1790132.html

python中函式引數的傳遞是透過賦值來傳遞的。函式引數的使用又有倆個方面值得注意:1.函式引數是如何定義的 2.在呼叫函式的過程中引數是如何被解析

先看第一個問題,在python中函式引數的定義主要有四種方式:
1.F(arg1,arg2,...)
這 是最常見的定義方式,一個函式可以定義任意個引數,每個引數間用逗號分割,用這種方式定義的函式在呼叫的的時候也必須在函式名後的小括號裡提供個數相等的 值(實際引數),而且順序必須相同,也就是說在這種呼叫方式中,形參和實參的個數必須一致,而且必須一一對應,也就是說第一個形參對應這第一個實參。例 如:
def a(x,y):
print x,y
呼叫該函式,a(1,2)則x取1,y取2,形參與實參相對應,如果a(1)或者a(1,2,3)則會報錯。


2.F(arg1,arg2=value2,...)
這種方式就是第一種的改進版,提供了預設值
def a(x,y=3):
print x,y
呼叫該函式,a(1,2)同樣還是x取1,y取2,但是如果a(1),則不會報錯了,這個時候x還是1,y則為預設的3。上面這倆種方式,還可以更換引數位置,比如a(y=8,x=3)用這種形式也是可以的。


3.F(*arg1)
上 面倆個方式是有多少個形參,就傳進去多少個實參,但有時候會不確定有多少個引數,則此時第三種方式就比較有用,它以一個*加上形參名的方式來表示這個函式 的實參個數不定,可能為0個也可能為n個。注意一點是,不管有多少個,在函式內部都被存放在以形參名為識別符號的tuple中。
>>> def a(*x):
if len(x)==0:
print 'None'
else:
print x
>>> a(1)
(1,)        #存放在元組中
>>> a()
None
>>> a(1,2,3)
(1, 2, 3)
>>> a(m=1,y=2,z=3)

Traceback (most recent call last):
File "<pyshell#16>", line 1, in -toplevel-
a(m=1,y=2,z=3)
TypeError: a() got an unexpected keyword argument 'm'


4.F(**arg1)
形參名前加倆個*表示,引數在函式內部將被存放在以形式名為識別符號的dictionary中,這時呼叫函式的方法則需要採用arg1=value1,arg2=value2這樣的形式。
>>> def a(**x):
if len(x)==0:
print 'None'
else:
print x  
>>> a()
None
>>> a(x=1,y=2)
{'y': 2, 'x': 1}      #存放在字典中
>>> a(1,2)            #這種呼叫則報錯

Traceback (most recent call last):
File "<pyshell#25>", line 1, in -toplevel-
a(1,2)
TypeError: a() takes exactly 0 arguments (2 given)


上面介紹了四種定義方式,接下來看函式引數在呼叫過程中是怎麼被解析的,其實只要記住上面這四種方法優先順序依次降低,先1,後2,再3,最後4,也就是先把方式1中的arg解析,然後解析方式2中的arg=value,再解析方式3,即是把多出來的arg這種形式的實參組成個tuple傳進去,最後把剩下的key=value這種形式的實參組成一個dictionary傳給帶倆個星號的形參,也就方式4
>>> def test(x,y=1,*a,**b):
print x,y,a,b


>>> test(1)
1 1 () {}
>>> test(1,2)
1 2 () {}
>>> test(1,2,3)
1 2 (3,) {}
>>> test(1,2,3,4)
1 2 (3, 4) {}
>>> test(x=1,y=2)
1 2 () {}
>>> test(1,a=2)
1 1 () {'a': 2}
>>> test(1,2,3,a=4)
1 2 (3,) {'a': 4}
>>> test(1,2,3,y=4)

Traceback (most recent call last):
File "<pyshell#52>", line 1, in -toplevel-
test(1,2,3,y=4)
TypeError: test() got multiple values for keyword argument 'y'

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/26250550/viewspace-1816284/,如需轉載,請註明出處,否則將追究法律責任。

相關文章