前言
一個函數可以有多個參數,而在有的情況下有的參數先得到,有的參數需要在后面的情景中才能知道,python 給我們提供了partial函數用于攜帶部分參數生成一個新函數。
在functools模塊中有一個工具partial(),可以用來"凍結"一個函數的參數,并返回"凍結"參數后的新函數。
很簡單的解釋,也是官方手冊給的示例。對于int()函數,它可以將給定的數值轉換成十進制整數,轉換時可以指定以幾進制的方式解析給定的數。例如:
# 以10進制解析123,并轉換成10進制整數>>> int("123")123# 以2進制解析10101,并轉換成10進制整數>>> int("10101", base=2)21# 以13進制解析"abc12c",并轉換成10進制整數>>> int("abc12c", base=13)4053672現在不想這樣指定base=2參數來將二進制轉換為10進制整數了,而是像普通函數一樣,直接指定待轉換的值即可。于是,定義另外一個函數來封裝int(),例如:
def inttwo(x): return int(x, base=2)inttwo("10101")functools中提供的partial()就是做類似事情的:
inttwo = partial(int, base=2)
它表示int()中指定參數base=2,也就是"凍結"了這個參數。
>>> from functools import partial>>> inttwo = partial(int,base=2)>>> inttwo("10101")21之所以"凍結"加上了引號,是因為可以在inttwo()中再次指定參數來覆蓋partial()中"凍結"的參數:
>>> inttwo("10101",base=10)10101回頭再看partial()的定義:
functools.partial(func, *args, **keywords)
從它的定義不難知道,不僅僅是像int()中base這樣的kw參數格式,位置參數args也一樣能"凍結"。
partial()返回的其實是一個partial對象,這個對象包含了3個特殊的屬性:
>>> dir(inttwo)[...... 'args', 'func', 'keywords']func表示該對象所封裝的原始函數 args表示"凍結"的位置參數列表 keywords表示"凍結"的關鍵字參數
>>> inttwo.func<class 'int'>>>> inttwo.args()>>> inttwo.keywords{'base': 2}另外需要注意的是,partial()不會保留封裝函數的元數據,比如注釋文檔、注解等。
>>> def myfunc(x:int, y:int) -> int:... ''' sum x + y '''... return x + y# 函數元數據信息>>> myfunc.__doc__' sum x + y '>>> myfunc.__annotations__{'x': <class 'int'>, 'y': <class 'int'>, 'return': <class 'int'>}# partial()包裝后的函數,沒有函數元數據>>> newfunc = functools.partial(myfunc,y=3)所以如果需要這些元數據,必須自己手動將元數據賦值給partial對象:
新聞熱點
疑難解答