Python有没有一种使用decorator包装类函数的方法?

Python有没有一种使用decorator包装类函数的方法?,python,Python,最后,我修复了如下ask use代码:(2018-06-03) 那不是pyhonic对吧?我是python的新手 //////旧的 class D: def __init__(self): self.handlers={} def check(self,func): self.handlers['h']=func def decorator(*args,**kwargs): return func(*ar

最后,我修复了如下ask use代码:(2018-06-03)

那不是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)

感谢大家。我问这个问题是因为我试着写一个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

装饰器,因此在创建函数注册为方法的类之前

因此,传递到decorator中的
func
不绑定到实例,并且不能在不显式传递实例的情况下调用它。此外,您没有访问存储在
t
中的实例的权限,该实例完全是在decorator之外创建的

您必须显式地传递实例,以便在上调用该方法:

t = Test()
d.call(t, 123)
或者在创建实例后,在
\uuu init\uu
方法中注册方法。方法作为实例上的属性进行查找时,将绑定这些方法。只有绑定的方法才引用要绑定到
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>
>>类Foo:
...     def bar(自):
...         回归自我
...
>>>Foo.bar#未绑定
>>>Foo.bar()#没有绑定的自我
回溯(最近一次呼叫最后一次):
文件“”,第1行,在
TypeError:bar()缺少1个必需的位置参数:“self”
>>>instance=Foo()
>>>instance.bar#绑定方法
>>>instance.bar.\uuuuself\uuuuuuuuuu是实例的实例
符合事实的
>>>instance.bar()#因此该实例是为self传入的
>>>Foo.bar(实例)#或者您可以手动执行
如果您确实将注册修复为存储绑定方法,则需要考虑到注册现在是对实例的额外引用,即使删除了对实例的所有其他引用,也要使其在内存中保持活动状态。如果这是一个问题,您需要使用对未绑定函数和实例的弱引用,而不是对方法的弱引用,因为方法是动态创建的,并且通常没有对它们的其他引用。请参见

声明函数时应用修饰符,因此就在创建函数注册为方法的类之前

因此,传递到decorator中的
func
不绑定到实例,并且不能在不显式传递实例的情况下调用它。此外,您没有访问存储在
t
中的实例的权限,该实例完全是在decorator之外创建的

您必须显式地传递实例,以便在上调用该方法:

t = Test()
d.call(t, 123)
或者在创建实例后,在
\uuu init\uu
方法中注册方法。方法作为实例上的属性进行查找时,将绑定这些方法。只有绑定的方法才引用要绑定到
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>
>>类Foo:
...     def bar(自):
...         回归自我
...
>>>Foo.bar#未绑定
>>>Foo.bar()#没有绑定的自我
回溯(最近一次呼叫最后一次):
文件“”,第1行,在
TypeError:bar()缺少1个必需的位置参数:“self”
>>>instance=Foo()
>>>instance.bar#绑定方法
>>>instance.bar.\uuuuself\uuuuuuuuuu是实例的实例
符合事实的
>>>instance.bar()#因此该实例是为self传入的
>>>Foo.bar(实例)#或者您可以手动执行

如果您确实将注册修复为存储绑定方法,则需要考虑到注册现在是对实例的额外引用,即使删除了对实例的所有其他引用,也要使其在内存中保持活动状态。如果这是一个问题,您需要使用对未绑定函数和实例的弱引用,而不是对方法的弱引用,因为方法是动态创建的,并且通常没有对它们的其他引用。请参见装饰器的
内部功能有什么意义?为什么不原封不动地返回
func
呢?我不明白。decorator和
调用
函数应该做什么?@Aran Fey:想象一个事件处理程序系统,OP想在类中将这些方法注册为事件回调。@MartijnPieters,这没有任何意义。没有可以传递给
prt
方法的
Test
实例。如果这就是他们想要做的,那根本就是有缺陷的。如果你是对的,OP需要解释哪个
Test
实例应该传递给
prt
以及为什么。@Aran Fey:这是此类系统中常见的缺陷,是的。您和我都知道,在创建类对象之前,就已经对函数应用了装饰器,以及绑定是如何工作的。对于不熟悉Python的人来说,这非常神奇,他们并不总是清楚为什么传递给装饰器的函数没有填充
self
。装饰器
内部函数的意义是什么?为什么不原封不动地返回
func
呢?我不明白。decorator和
调用
函数应该做什么?@Aran Fey:想象一个事件处理程序系统,OP想在类中将这些方法注册为事件回调。@MartijnPieters,这没有任何意义。没有可以传递给
prt
方法的
Test
实例。如果这就是他们想要做的,那根本就是有缺陷的。如果你是对的,OP需要解释哪个
Test
实例应该传递给
prt
以及为什么。@Aran Fey:这是此类系统中常见的缺陷,是的。您和我都知道,在创建类对象之前,就已经对函数应用了装饰器,以及绑定是如何工作的。对于不熟悉Python的人来说,这是非常神奇的,他们并不总是清楚为什么传递给装饰器的函数没有
self