在使用类定义修饰符时,如何自动转移到 __name__、 __module__和 __doc__上?通常,我会使用 funtools 中的@wraps 装饰器。下面是我为一个类所做的改动(这不完全是我的代码) :
class memoized:
"""Decorator that caches a function's return value each time it is called.
If called later with the same arguments, the cached value is returned, and
not re-evaluated.
"""
def __init__(self, func):
super().__init__()
self.func = func
self.cache = {}
def __call__(self, *args):
try:
return self.cache[args]
except KeyError:
value = self.func(*args)
self.cache[args] = value
return value
except TypeError:
# uncacheable -- for instance, passing a list as an argument.
# Better to not cache than to blow up entirely.
return self.func(*args)
def __repr__(self):
return self.func.__repr__()
def __get__(self, obj, objtype):
return functools.partial(self.__call__, obj)
__doc__ = property(lambda self:self.func.__doc__)
__module__ = property(lambda self:self.func.__module__)
__name__ = property(lambda self:self.func.__name__)
是否有标准的装饰器来自动创建名称模块和文档?另外,为了自动化 get 方法(我假设这是为了创建绑定方法?)有什么遗漏的方法吗?