我正在尝试对一个具有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
答案 0 :(得分:3)
如何定义函数并不重要;它只是在class
定义末尾的类的名称空间中的一个函数,因此,就像在此定义的任何其他函数一样对待。 class
块是功能齐全的Python代码,唯一重要的是该块末尾的结果是什么。
您想要的是用staticmethod
装饰函数:
class MultiplierFilter:
function = staticmethod(mult)
这将防止在呼叫时隐式传递self
。