淺談python標(biāo)準(zhǔn)庫(kù)--functools.partial
一.簡(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ù)。

創(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詳解整合,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
python中日志logging模塊的性能及多進(jìn)程詳解
使用Python來(lái)寫(xiě)后臺(tái)任務(wù)時(shí),時(shí)常需要使用輸出日志來(lái)記錄程序運(yùn)行的狀態(tài),并在發(fā)生錯(cuò)誤時(shí)將錯(cuò)誤的詳細(xì)信息保存下來(lái),以別調(diào)試和分析。Python的logging模塊就是這種情況下的好幫手。本文就介紹了python中日志logging模塊性能及多進(jìn)程的相關(guān)資料,需要的朋友可以參考下。2017-07-07
Python通過(guò)Tesseract庫(kù)實(shí)現(xiàn)文字識(shí)別
這篇文章主要介紹了Python通過(guò)Tesseract庫(kù)實(shí)現(xiàn)文字識(shí)別,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-03-03
Python實(shí)現(xiàn)子類(lèi)調(diào)用父類(lèi)的初始化實(shí)例
這篇文章主要介紹了Python實(shí)現(xiàn)子類(lèi)調(diào)用父類(lèi)的初始化實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-03-03
python實(shí)現(xiàn)將html表格轉(zhuǎn)換成CSV文件的方法
這篇文章主要介紹了python實(shí)現(xiàn)將html表格轉(zhuǎn)換成CSV文件的方法,涉及Python操作csv文件的相關(guān)技巧,需要的朋友可以參考下2015-06-06
解決pyinstaller打包exe文件出現(xiàn)命令窗口一閃而過(guò)的問(wèn)題
今天小編就為大家分享一篇解決pyinstaller打包exe文件出現(xiàn)命令窗口一閃而過(guò)的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-10-10
Python中TypeError: int object is not 
在Python中,當(dāng)你嘗試對(duì)一個(gè)非迭代對(duì)象(如整數(shù)、浮點(diǎn)數(shù)等)使用迭代操作(如for循環(huán)、列表推導(dǎo)式中的迭代等)時(shí),會(huì)觸發(fā)TypeError: 'int' object is not iterable錯(cuò)誤,所以本文給大家介紹了Python中TypeError: int object is not iterable錯(cuò)誤分析及解決辦法2024-08-08
python 實(shí)現(xiàn)返回一個(gè)列表中出現(xiàn)次數(shù)最多的元素方法
今天小編就為大家分享一篇python 實(shí)現(xiàn)返回一個(gè)列表中出現(xiàn)次數(shù)最多的元素方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-06-06
Flask 驗(yàn)證碼自動(dòng)生成的實(shí)現(xiàn)示例
本文主要介紹了Flask 驗(yàn)證碼自動(dòng)生成的實(shí)現(xiàn)示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2025-03-03

