[英]Python Is there a way to use decorator wrap a function of class?
最后我修复了这样的请使用代码,如下所示:(2018-06-03)
class Main:
@app.route('^/$')
def default(self):
return 'hello from class ccc'
module=sys.modules[func.__module__]
cls=getattr(module,func.__qualname__.replace('.'+func.__name__,''))
ins=cls()
m=getattr(cls,func.__name__)
resp.body=m(cls) #func.__module__+'.'+func.__qualname__+' func:'+func.__name__
这不是发烧的权利吗?我是python的新手
//////旧
class D:
def __init__(self):
self.handlers={}
def check(self,func):
self.handlers['h']=func
def decorator(*args,**kwargs):
return func(*args,**kwargs)
return decorator
def call(self,p):
return self.handlers['h'](p)
d=D()
class Test:
@d.check
def prt(self,v):
print(v)
t=Test()
d.call(123)
错误信息:prt()缺少1个必需的位置参数:'v'
似乎需要一个名为“ self”的参数,但如何传递呢?
//编辑(2018-06-01)
谢谢大家。我问这个原因,我尝试编写一个python web框架,并且我想路由到下面的类方法
app=MyFrm()
class Controller:
@app.route('/')
def hello():
return 'hello world'
但是现有的方法如下所示,这是没有必要的,还是没有人可以在python中做到这一点?
app = Flask(__name__)
@app.route("/")
def hello():
return "Hello World!"
现在我使用@staticmethod解决了这个问题
在声明函数时应用装饰器,因此在创建将函数注册为方法的类之前。
因此,传递给装饰器的func
并没有绑定到实例 ,并且您不能在没有显式传递实例的情况下直接调用它。 此外,您无权访问完全在装饰器外部创建的t
存储的实例。
您必须显式传递实例以在以下位置调用方法:
t = Test()
d.call(t, 123)
或在创建实例后在__init__
方法中注册方法。 当您通过decriptor协议将方法作为实例的属性来查找时,方法便受到绑定。 仅绑定方法具有对要绑定到self
的实例的引用:
>>> class Foo:
... def bar(self):
... return self
...
>>> Foo.bar # unbound
<function Foo.bar at 0x108d38f28>
>>> Foo.bar() # no self to bind to
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
TypeError: bar() missing 1 required positional argument: 'self'
>>> instance = Foo()
>>> instance.bar # bound method
<bound method Foo.bar of <__main__.Foo object at 0x109a916d8>>
>>> instance.bar.__self__ is instance # to the instance
True
>>> instance.bar() # so the instance is passed in for self
<__main__.Foo object at 0x109a916d8>
>>> Foo.bar(instance) # or you can do it manually
<__main__.Foo object at 0x109a916d8>
如果您确实将注册修改为存储绑定方法,则需要考虑到注册现在是对实例的额外引用,即使删除了对该实例的所有其他引用,该注册也仍保留在内存中。 如果这是一个问题,则需要使用对未绑定函数和实例的弱引用 ,而不是对方法的弱引用 ,因为方法是动态创建的, 并且通常没有其他引用 。 请参阅使用python WeakSet启用回调功能
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.