Python functools.partial - 如何使用静态装饰器将其应用于 class 方法

Python functools.partial - How to apply it to a class method with the static decorator

我知道一定有办法做到这一点。但我收到错误 "TypeError: the first argument must be callable".

我可以做些什么不同的事情来完成这项工作?

class FaxMachine(object):
    MODEL_NO = '100'

    @staticmethod
    def load_fax(fax, error=''):
        # send fax here

    fail_fax = functools.partial(load_fax, error='PC LOAD LETTER')

staticmethod 对象不可调用。它们 descriptors 在其 __func__ 属性中保留对原始函数的引用。

因此以下工作:

# Note: apply staticmethod again
fail_fax = staticmethod(partial(load_fax.__func__, error='PC LOAD LETTER'))

您还可以在 class 命名空间中定义辅助函数,以避免不必要的属性查找:

def _load_fax(fax, error=''):
    # ...

# _load_fax is an ordinary function
load_fax = staticmethod(_load_fax)
fail_fax = staticmethod(partial(_load_fax, error='PC LOAD LETTER'))

虽然正确的 Python 3.4+ 解决方案是使用 partialmethod,它被设计用于描述符:

fail_fax = partialmethod(load_fax, error='PC LOAD LETTER')

方法和函数在 "called" 时的行为不同:使用 __call__ 直接调用函数,而 __get__ 调用方法(通常不是方法,我认为只有描述符)。

因此 functools-模块包含另一个 partial 方法:functools.partialmethod:

functools.partialmethod(load_fax, error='PC LOAD LETTER')

官方文档包含非常好的解释,尤其是关于 staticmethod

可能有更聪明的方法,但这似乎工作正常。

import functools

class FaxMachine(object):
    MODEL_NO = '100'

    @staticmethod
    def load_fax(fax, error=''):
        print error or fax

FaxMachine.fail_fax = functools.partial(FaxMachine.load_fax, error='PC LOAD LETTER')

f = FaxMachine()
f.load_fax('hi')
f.fail_fax('hi')