如何使用类的__call__函数编写装饰器?

时间:2015-01-26 05:51:04

标签: python django decorator python-decorators

以下是我的代码。给定任何内容,它必须在前面的内容中附加某些HTML标记。 我正在学习使用调用而不是函数闭包来编写装饰器。

class decorate:
    def __init__(self, tag=""):
        self.tag = tag
    def __call__(self, function, *args):
        return "<p>{}</p>".format(self.tag, function(*args), self.tag)

@decorate(tag="p")
def get_content(content):
    return content    

print(get_content("I'm awesome"))

# Error i got.
Traceback (most recent call last):
  File "cache.py", line 27, in <module>
    @decorate(tag="p")
  File "cache.py", line 25, in __call__
    return "<p>{}</p>".format(self.tag, function(*args), self.tag)
TypeError: get_content() takes exactly 1 argument (0 given)

1 个答案:

答案 0 :(得分:3)

变化:

def __call__(self, function, *args):
    return "<p>{}</p>".format(self.tag, function(*args), self.tag)

成:

def __call__(self, function):
   def wrap(*args):
       return "<{}>{}</{}>".format(self.tag, function(*args), self.tag)
   return wrap

您可能需要查看functools以获得更精致的wrap装饰,但除了支持help之外,这应该可行。