装饰子类方法

Cha*_*net 2 python decorator python-decorators

假设我有一堂课Foo.我写了一个装饰器,deco我想申请一些类的方法Foo.既然Foo从库中导入,我决定将其子类化为Bar.现在,我唯一需要做的就是将装饰器添加到某些方法中Foo.

class Bar(Foo):

    @deco
    def aMethod(self, *args, **kwargs):
        super().aMethod(*args, **kwargs)
Run Code Online (Sandbox Code Playgroud)

由于我不需要修改代码aMethod,有没有更简单的方法来装饰它,而不需要明确地调用super()

Mar*_*ers 5

你可以Foo通过用装饰版本替换方法来monkeypatch :

Foo.aMethod = deco(Foo.aMethod)
Run Code Online (Sandbox Code Playgroud)

装饰器语法只是语法糖,毕竟deco只是一个可调用的,其结果取代了修饰函数:

@deco
def aMethod(...):
    ....
Run Code Online (Sandbox Code Playgroud)

被有效地翻译成:

def aMethod(....):
    ...
aMethod = deco(aMethod)
Run Code Online (Sandbox Code Playgroud)

或者,如果您仍然喜欢使用子类,请在类的主体中执行相同的操作:

class Bar(Foo):
    aMethod = deco(Foo.aMethod)
Run Code Online (Sandbox Code Playgroud)

在Python 2中,您需要首先解开函数:

Foo.aMethod = deco(Foo.aMethod.im_func)
Run Code Online (Sandbox Code Playgroud)