成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

您的位置:首頁技術文章
文章詳情頁

Python如何解除一個裝飾器

瀏覽:4日期:2022-07-14 16:50:50

問題

一個裝飾器已經作用在一個函數上,你想撤銷它,直接訪問原始的未包裝的那個函數。

解決方案

假設裝飾器是通過 @wraps 來實現的,那么你可以通過訪問 __wrapped__ 屬性來訪問原始函數:

>>> @somedecorator>>> def add(x, y):... return x + y...>>> orig_add = add.__wrapped__>>> orig_add(3, 4)7>>>

討論

直接訪問未包裝的原始函數在調試、內省和其他函數操作時是很有用的。 但是我們這里的方案僅僅適用于在包裝器中正確使用了 @wraps 或者直接設置了 __wrapped__ 屬性的情況。

如果有多個包裝器,那么訪問 __wrapped__ 屬性的行為是不可預知的,應該避免這樣做。 在Python3.3中,它會略過所有的包裝層,比如,假如你有如下的代碼:

from functools import wrapsdef decorator1(func): @wraps(func) def wrapper(*args, **kwargs): print(’Decorator 1’) return func(*args, **kwargs) return wrapperdef decorator2(func): @wraps(func) def wrapper(*args, **kwargs): print(’Decorator 2’) return func(*args, **kwargs) return wrapper@decorator1@decorator2def add(x, y): return x + y

下面我們在Python3.3下測試:

>>> add(2, 3)Decorator 1Decorator 25>>> add.__wrapped__(2, 3)5>>>

下面我們在Python3.4下測試:

>>> add(2, 3)Decorator 1Decorator 25>>> add.__wrapped__(2, 3)Decorator 25>>>

最后要說的是,并不是所有的裝飾器都使用了 @wraps ,因此這里的方案并不全部適用。 特別的,內置的裝飾器 @staticmethod 和 @classmethod 就沒有遵循這個約定 (它們把原始函數存儲在屬性 __func__ 中)。

以上就是Python如何解除一個裝飾器的詳細內容,更多關于Python 解除裝飾器的資料請關注好吧啦網其它相關文章!

標簽: Python 編程
相關文章: