我真的不需要这样做,但只是想知道,有没有办法将装饰器绑定到类中的所有函数,而不是明确地为每个函数声明它.
我认为它然后变成了一种方面,而不是装饰者,它确实感觉有点奇怪,但是想到时间或认证这样的东西它会非常整洁.
我正在尝试编写一个类装饰器,它将装饰器应用于所有类的方法:
import inspect
def decorate_func(func):
def wrapper(*args, **kwargs):
print "before"
ret = func(*args, **kwargs)
print "after"
return ret
for attr in "__module__", "__name__", "__doc__":
setattr(wrapper, attr, getattr(func, attr))
return wrapper
def decorate_class(cls):
for name, meth in inspect.getmembers(cls, inspect.ismethod):
setattr(cls, name, decorate_func(meth))
return cls
@decorate_class
class MyClass(object):
def __init__(self):
self.a = 10
print "__init__"
def foo(self):
print self.a
@staticmethod
def baz():
print "baz"
@classmethod
def bar(cls):
print "bar"
obj = MyClass()
obj.foo()
obj.baz()
MyClass.baz()
obj.bar()
MyClass.bar()
Run Code Online (Sandbox Code Playgroud)
它几乎可以工作,但@classmethodS需要特殊处理:
$ python …Run Code Online (Sandbox Code Playgroud) 在诸如Python: Do Something for any method of a class? 等问题中,有一些有趣的方法可以在类中的每个方法之前运行方法。
然而,该解决方案不允许我们传递参数。
对于类中的所有函数,有一个关于捕获“函数调用之前/之后”事件的装饰器解决方案,但我不想返回并装饰我的所有类。
有没有一种方法可以运行依赖于每次调用对象方法时传递的参数的前/后操作?
例子:
class Stuff(object):
def do_stuff(self, stuff):
print(stuff)
a = Stuff()
a.do_stuff('foobar')
"Pre operation for foobar"
"foobar"
"Post operation for foobar"
Run Code Online (Sandbox Code Playgroud)