有没有办法查看 Python 装饰器的应用程序对我应用它的函数做了什么。例如,如果我有
class A(object):
@property
def something(self):
return 0
我想看看something
实际执行的代码是什么样的。有没有办法做到这一点?
有没有办法查看 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)
例如,对@
符号后面的表达式求值,然后调用结果,传入该@
行后面的函数或类。然后装饰器返回的任何内容都会替换原始对象。
出于自省目的,不保留该@
行;您必须解析源代码本身才能发现存在的任何装饰器。装饰器没有义务返回一个新对象;您可以原封不动地返回原始对象,但您无法通过内省了解其中的区别。
你最好的选择是返回装饰器的源代码,然后阅读代码。装饰器是用 C 实现的property
,但描述符 howto包含一个 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__)