有没有办法查看 Python 装饰器的应用程序对我应用它的函数做了什么。例如,如果我有

class A(object):

   @property
   def something(self):
       return 0

我想看看执行的代码是什么 something 实际上看起来像。有没有办法做到这一点?

有帮助吗?

解决方案

装饰器不生成代码;而是生成代码。装饰器实际上只是语法糖:

@property
def something(self):
    return 42

实际上被解释为:

def something(self):
    return 42
something = property(something)

例如后面的表达式 @ 计算符号,并调用结果,传入紧随其后的函数或类 @ 线。无论装饰者返回什么 取代 原始对象。

出于自省的目的, @ 线是 不是 保留;您必须解析源代码本身才能发现存在的任何装饰器。装饰器没有义务返回一个新对象;您可以返回未更改的原始对象,并且通过内省您无法知道其中的区别。

最好的选择是返回装饰器的源代码并阅读代码。这 property 装饰器是用C实现的,但是 描述符指南 包含一个执行相同操作的 Python 实现:

class Property(object):
    "Emulate PyProperty_Type() in Objects/descrobject.c"

    def __init__(self, fget=None, fset=None, fdel=None, doc=None):
        self.fget = fget
        self.fset = fset
        self.fdel = fdel
        if doc is None and fget is not None:
            doc = fget.__doc__
        self.__doc__ = doc

    def __get__(self, obj, objtype=None):
        if obj is None:
            return self
        if self.fget is None:
            raise AttributeError("unreadable attribute")
        return self.fget(obj)

    def __set__(self, obj, value):
        if self.fset is None:
            raise AttributeError("can't set attribute")
        self.fset(obj, value)

    def __delete__(self, obj):
        if self.fdel is None:
            raise AttributeError("can't delete attribute")
        self.fdel(obj)

    def getter(self, fget):
        return type(self)(fget, self.fset, self.fdel, self.__doc__)

    def setter(self, fset):
        return type(self)(self.fget, fset, self.fdel, self.__doc__)

    def deleter(self, fdel):
        return type(self)(self.fget, self.fset, fdel, self.__doc__)
许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top