描述符可以自动检测传递给它的对象的名称吗?
class MyDecorator( object ):
def __init__(self, wrapped):
# Detect that wrapped's name is 'some_attr' here
pass
class SomeClass( object ):
some_attr = dict()
wrapper = MyDecorator( some_attr )
描述符可以自动检测传递给它的对象的名称吗?
class MyDecorator( object ):
def __init__(self, wrapped):
# Detect that wrapped's name is 'some_attr' here
pass
class SomeClass( object ):
some_attr = dict()
wrapper = MyDecorator( some_attr )
不,不是。您可以通过调用框架的自省来破解某些东西,但这不是一个好的 - 或强大的 - 解决方案。(如果 SomeClass 有两个描述符,你会怎么做some_attr=MyDecorator()
??someother_attr=some_attr
)
最好是明确的:
def mydecorator(attr):
class MyDecorator( object ):
def __get__(self,inst,instcls):
print(attr)
return MyDecorator()
class SomeClass( object ):
some_attr = mydecorator('some_attr')
someother_attr = mydecorator('someother_attr')
s=SomeClass()
s.some_attr
# some_attr
s.someother_attr
# someother_attr
(为后代回答我自己的问题。)
这是迄今为止我想出的最好的:
class MyDecorator( object ):
def __init__(self, wrapped):
import inspect
for name, obj in inspect.stack(2)[1][0].f_locals.iteritems():
if wrapped is obj:
print "wrapped attribute is called", name
break
else:
raise RuntimeError("Failed to auto-detect attribute name")