Python有没有办法使用decorator包装类的函数?

时间:2018-06-01 18:16:59

标签: python

最后我修复了这个问题使用代码如下:(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__

那不是pyhonic对吗?我是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)

感谢all。我问这个原因我尝试编写一个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

解决了这个问题

1 个答案:

答案 0 :(得分:4)

当声明函数时,将应用装饰器,因此就在创建类之前,函数被注册为方法。

因此传递给装饰器的func 未绑定到实例,并且您无法在不明确传入实例的情况下调用它。此外,您无法访问存储在t中的实例,该实例完全是在装饰器之外创建的。

您必须明确传递实例才能调用方法:

t = Test()
d.call(t, 123)

或在{/ 1}}方法中创建实例后注册方法。通过decriptor protocol将方法作为实例上的属性进行查找时绑定方法。只有绑定方法才能引用要绑定到__init__的实例:

self

如果您 修复您的注册以存储绑定方法,您需要考虑注册现在是对实例的额外引用,即使它在内存中保持活动,即使将删除对该实例的所有其他引用。如果这是一个问题,您需要使用对未绑定函数和实例的弱引用,而不是方法,因为方法是动态创建的,通常没有其他引用给他们。见using python WeakSet to enable a callback functionality