Python使用functools模塊中的partial函數(shù)生成偏函數(shù)
python 中提供一種用于對函數(shù)固定屬性的函數(shù)(與數(shù)學上的偏函數(shù)不一樣)
# 通常會返回10進制 int('12345') # print 12345 # 使用參數(shù) 返回 8進制 int('11111', 8) # print 4681
每次都得添加參數(shù)比較麻煩, functools提供了partial的方法
import functools foo = functools.partial(int, base=8) foo('11111') # print 4681
通過這種方法生成一個固定參數(shù)的新函數(shù).
假設要轉換大量的二進制字符串,每次都傳入int(x, base=2)非常麻煩,于是,我們想到,可以定義一個int2()的函數(shù),默認把base=2傳進去:
def int2(x, base=2): return int(x, base)
這樣,我們轉換二進制就非常方便了:
>>> int2('1000000') 64 >>> int2('1010101') 85
functools.partial就是幫助我們創(chuàng)建一個偏函數(shù)的,不需要我們自己定義int2(),可以直接使用下面的代碼創(chuàng)建一個新的函數(shù)int2:
>>> import functools >>> int2 = functools.partial(int, base=2) >>> int2('1000000') 64 >>> int2('1010101') 85
所以,簡單總結functools.partial的作用就是,把一個函數(shù)的某些參數(shù)給固定?。ㄒ簿褪窃O置默認值),返回一個新的函數(shù),調(diào)用這個新函數(shù)會更簡單。
注意到上面的新的int2函數(shù),僅僅是把base參數(shù)重新設定默認值為2,但也可以在函數(shù)調(diào)用時傳入其他值:
>>> int2('1000000', base=10) 1000000
最后,創(chuàng)建偏函數(shù)時,實際上可以接收函數(shù)對象、*args和**kw這3個參數(shù),當傳入:
int2 = functools.partial(int, base=2)
實際上固定了int()函數(shù)的關鍵字參數(shù)base,也就是:
int2('10010')
相當于:
kw = { 'base': 2 } int('10010', **kw)
當傳入:
max2 = functools.partial(max, 10)
實際上會把10作為*args的一部分自動加到左邊,也就是:
max2(5, 6, 7)
相當于:
args = (10, 5, 6, 7) max(*args)
結果為10。
相關文章
Python編程實現(xiàn)微信企業(yè)號文本消息推送功能示例
這篇文章主要介紹了Python編程實現(xiàn)微信企業(yè)號文本消息推送功能,結合實例形式分析了Python微信企業(yè)號文本消息推送接口的調(diào)用相關操作技巧,需要的朋友可以參考下2017-08-08Python初識二叉樹續(xù)之實戰(zhàn)binarytree
binarytree庫是一個Python的第三方庫,這個庫實現(xiàn)了一些二叉樹相關的常用方法,使用二叉樹時,可以直接調(diào)用,不需要再自己實現(xiàn),下面這篇文章主要給大家介紹了關于Python初識二叉樹之實戰(zhàn)binarytree的相關資料,需要的朋友可以參考下2022-05-05Python標準庫中內(nèi)置裝飾器@staticmethod和@classmethod
裝飾器是Python中強大而靈活的功能,用于修改或增強函數(shù)或方法的行為,本文就來介紹一下Python標準庫中內(nèi)置裝飾器@staticmethod和@classmethod,感興趣的可以了解一下2023-10-10關于Python使用logging庫進行有效日志管理的方法詳解
在開發(fā)大型軟件或處理復雜問題時,我們經(jīng)常需要一種方法來記錄和跟蹤程序的運行狀態(tài),Python 提供了一個名為 logging 的標準庫,可以幫助我們更好地完成這項任務,在這篇文章中,我們將介紹如何使用 Python 的 logging 庫進行日志記錄2023-06-06Pytorch使用CUDA流(CUDA?stream)的實現(xiàn)
本文主要介紹了Pytorch使用CUDA流(CUDA?stream)的實現(xiàn),CUDA流是在GPU上并行執(zhí)行操作的一種機制,通過使用CUDA流,可以將不同的操作分配給不同的流,在不同的流上并行執(zhí)行這些操作,從而提高代碼的性能2023-12-12