溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

淺談python標(biāo)準(zhǔn)庫(kù)--functools.partial

發(fā)布時(shí)間:2020-10-11 18:50:21 來(lái)源:腳本之家 閱讀:205 作者:天星321 欄目:開(kāi)發(fā)技術(shù)

一.簡(jiǎn)單介紹:

 functools模塊用于高階函數(shù):作用于或返回其他函數(shù)的函數(shù)。一般而言,任何可調(diào)用對(duì)象都可以作為本模塊用途的函數(shù)來(lái)處理。

 functools.partial返回的是一個(gè)可調(diào)用的partial對(duì)象,使用方法是partial(func,*args,**kw),func是必須要傳入的,而且至少需要一個(gè)args或是kw參數(shù)。

淺談python標(biāo)準(zhǔn)庫(kù)--functools.partial

創(chuàng)建一個(gè)功能函數(shù),實(shí)現(xiàn)三個(gè)數(shù)的相加,如果其中的一個(gè)或是多個(gè)參數(shù)不變,那么可以使用partial,實(shí)例化一個(gè)傳入了add和12參數(shù)的對(duì)象,如上圖所示,傳入兩個(gè)參數(shù)后,得到三個(gè)數(shù)的和。

二.partial源碼分析:

 1.__new__方法部分 

class partial:
 """New function with partial application of the given arguments
 and keywords.
 """
 ###__SLOTS__ 只允許類(lèi)有此屬性,不能動(dòng)態(tài)的添加其他的屬性
 __slots__ = "func", "args", "keywords", "__dict__", "__weakref__" 
 ###__new__方法生成實(shí)例對(duì)象
 def __new__(*args, **keywords):
 ###實(shí)例化對(duì)象時(shí)傳入?yún)?shù)的限定,不能為空、參數(shù)的個(gè)數(shù)要大于等于2,這就解釋了至少需要一個(gè)或多個(gè)args或是kw,func是一個(gè)可調(diào)用的對(duì)象,是必須要傳入的
 if not args: 
 raise TypeError("descriptor '__new__' of partial needs an argument")
 if len(args) < 2:
 raise TypeError("type 'partial' takes at least one argument")
 cls, func, *args = args # args=(cls,func,*args)
 if not callable(func):
 raise TypeError("the first argument must be callable")
 ### 位置參數(shù)是以元組的形式傳入的 
 args = tuple(args)
###hasattr這塊我也沒(méi)有咋個(gè)明白,不知道可以應(yīng)用到什么地方,從使用方法來(lái)看,傳入的函數(shù)func要有屬性或是方法,如果知道請(qǐng)告知我一下
 if hasattr(func, "func"):
 args = func.args + args
 tmpkw = func.keywords.copy()
 tmpkw.update(keywords)
 keywords = tmpkw
 del tmpkw
 func = func.func 
###創(chuàng)建一個(gè)實(shí)例對(duì)象本身
 self = super(partial, cls).__new__(cls)
###動(dòng)態(tài)的添加屬性
 self.func = func 
 self.args = args
 self.keywords = keywords
 return self

上面的代碼創(chuàng)建了一個(gè)實(shí)例對(duì)象(p=partial(func,*args,**kw)),并給對(duì)象本身添加了屬性。

2. __call__方法部分

再看可調(diào)用的部分,partial實(shí)例化的對(duì)象是一個(gè)可調(diào)用的,是因?yàn)樵趐artial中寫(xiě)了__call__方法,看源碼:

###在使用p()時(shí)會(huì)自動(dòng)調(diào)用__call__方法 
 def __call__(*args, **keywords):
 if not args:
 raise TypeError("descriptor '__call__' of partial needs an argument")
 self, *args = args
 ###將位置參數(shù)和關(guān)鍵字參數(shù)分別合在一起,在使用p()的時(shí)候只傳入了部分的參數(shù),這是為了我們的方便,不重復(fù)傳入不變的參數(shù),而在__call__方法中會(huì)將func所需的參數(shù)全部傳入 
 newkeywords = self.keywords.copy()
 newkeywords.update(keywords)
###*self.args是partial(func,*args,**kw)中的*args
 return self.func(*self.args, *args, **newkeywords)

在使用p(*args,**keywords)的時(shí)候,就會(huì)自動(dòng)的調(diào)用__call__方法,這就是生成的對(duì)象可調(diào)用的原因,self是實(shí)例化對(duì)象本身,*args、**kw是我們傳入函數(shù)func的參數(shù),但是只是傳入了部分參數(shù),這也是partial的作用所在,所以還要將partial(func,*args,**kw)中的位置參數(shù)和關(guān)鍵字參數(shù)與p(*args,**keywords)一并傳入到函數(shù)func中來(lái)實(shí)現(xiàn)函數(shù)的功能。官網(wǎng)中解釋partial的功能實(shí)現(xiàn)相當(dāng)于:

def partial(func, *args, **keywords):
 def newfunc(*fargs, **fkeywords):
 newkeywords = keywords.copy()
 newkeywords.update(fkeywords)
 return func(*args, *fargs, **newkeywords)
 newfunc.func = func
 newfunc.args = args
 newfunc.keywords = keywords
 return newfunc

當(dāng)調(diào)用partial函數(shù)的時(shí)候,返回的是newfunc函數(shù)對(duì)象,讓f=partial(add,12),相當(dāng)了f=newfunc,所以f是一個(gè)可調(diào)用的對(duì)象,因此f(1,2)-->等價(jià)于newfunc(1,2)-->將參數(shù)整合傳入到func中,并返回func實(shí)現(xiàn)其功能。

淺談python標(biāo)準(zhǔn)庫(kù)--functools.partial

以上所述是小編給大家介紹的python標(biāo)準(zhǔn)庫(kù)--functools.partial詳解整合,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)億速云網(wǎng)站的支持!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI