为什么分配给类属性的函数被视为实例方法?

时间:2019-06-26 10:00:22

标签: python object

我正在尝试对一个具有getCallable()方法返回一个函数的对象进行编程。我想将此函数作为类属性提供,这样我就可以继承父类,并为每个子类设置一个不同的函数。

在我的情况下,该对象是具有交互式输入字段的小部件,用户可以填充该小部件以设置大多数功能参数。

问题在于该函数似乎被视为实例方法,该实例在调用时作为第一个参数传递。

那是为什么?如何修改代码,以使实例不作为函数属性传递?

这是一个非常简化的示例,重现了我的问题:

def mult(a, b):
    return a * b


class MultiplierFilter(object):
    function = mult

    def __init__(self):
        super().__init__()
        self.multiplier = 1

    def parameters(self):
        return {
            "multiplier": self.multiplier}

    def setParameters(self, params):
        """
        :param dict params:
        :return:
        """
        self.multiplier = params.get("multiplier", 1)

    def getCallable(self):
        """Return a function that takes a number as only argument and returns
        another number.
        """
        mult = self.multiplier

        def f(value):
            return self.function(value, mult)
        return f


if __name__ == '__main__':
    multiplier_object = MultiplierFilter()
    multiplier_object.setParameters({"multiplier": 2})

    test_function = multiplier_object.getCallable()
    print(test_function(7.))

错误消息:

Traceback (most recent call last):
  File "C:/Users/Pierre/PycharmProjects/pyipsdk_tuto/2.py", line 39, in <module>
    print(test_function(7.))
  File "C:/Users/Pierre/PycharmProjects/pyipsdk_tuto/2.py", line 30, in f
    return self.function(value, mult)
TypeError: mult() takes 2 positional arguments but 3 were given

1 个答案:

答案 0 :(得分:3)

如何定义函数并不重要;它只是在class定义末尾的类的名称空间中的一个函数,因此,就像在此定义的任何其他函数一样对待。 class块是功能齐全的Python代码,唯一重要的是该块末尾的结果是什么。

您想要的是用staticmethod装饰函数:

class MultiplierFilter:
    function = staticmethod(mult)

这将防止在呼叫时隐式传递self