python - 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() missing 1 required positional argument: '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__
方法。当您通过descriptor protocol将它们作为实例上的属性查找时,方法是绑定的。只有绑定的方法具有对要绑定到的实例的引用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 启用回调功能
推荐阅读
- loss-function - 我试图在 Keras 中实现我自己的自定义损失函数,但它不起作用
- sql-server - 如何在 SQL Server 中的表列中获取缺失的日期
- node.js - 前端或后端的字段验证?哪个更好?
- javascript - 在 div 外部单击时隐藏子菜单
- go - Go 中的 CLI。显示流的结构
- java - 解析 .docx 文件以提取文本和图像
- python - 如何循环读取巨大的 CSV 文件
- python - 散景等值线图不随滑块改变
- javascript - 如何包含外部 JavaScript 以在 Excel 自定义函数中使用?
- sql - 列“Transaction_Master.Tranaction_Slno”无效