如何使用Python移除已添加的装饰器?
- 内容介绍
- 文章标签
- 相关推荐
本文共计593个文字,预计阅读时间需要3分钟。
问题:一个装饰器已经作用在一个函数上,你想撤销它,直接访问原始的未包装的那个函数。解决方案:假设装饰器是通过`@wraps`实现的,那么你可以通过访问`__wrapped__`属性来直接访问原始函数。
问题
一个装饰器已经作用在一个函数上,你想撤销它,直接访问原始的未包装的那个函数。
解决方案
假设装饰器是通过 @wraps 来实现的,那么你可以通过访问 __wrapped__ 属性来访问原始函数:
>>> @somedecorator >>> def add(x, y): ... return x + y ... >>> orig_add = add.__wrapped__ >>> orig_add(3, 4) 7 >>>
讨论
直接访问未包装的原始函数在调试、内省和其他函数操作时是很有用的。 但是我们这里的方案仅仅适用于在包装器中正确使用了 @wraps 或者直接设置了 __wrapped__ 属性的情况。
如果有多个包装器,那么访问 __wrapped__ 属性的行为是不可预知的,应该避免这样做。
本文共计593个文字,预计阅读时间需要3分钟。
问题:一个装饰器已经作用在一个函数上,你想撤销它,直接访问原始的未包装的那个函数。解决方案:假设装饰器是通过`@wraps`实现的,那么你可以通过访问`__wrapped__`属性来直接访问原始函数。
问题
一个装饰器已经作用在一个函数上,你想撤销它,直接访问原始的未包装的那个函数。
解决方案
假设装饰器是通过 @wraps 来实现的,那么你可以通过访问 __wrapped__ 属性来访问原始函数:
>>> @somedecorator >>> def add(x, y): ... return x + y ... >>> orig_add = add.__wrapped__ >>> orig_add(3, 4) 7 >>>
讨论
直接访问未包装的原始函数在调试、内省和其他函数操作时是很有用的。 但是我们这里的方案仅仅适用于在包装器中正确使用了 @wraps 或者直接设置了 __wrapped__ 属性的情况。
如果有多个包装器,那么访问 __wrapped__ 属性的行为是不可预知的,应该避免这样做。

