假设我有这门课程:
class MyClass(object):
def uiFunc(self, MainWindow):
self.attr1 = "foo"
self.attr2 = "bar"
def test():
from subclassfile import MySubClass
MySubClass.firstFunc(self, 2, 2)
test()
这个子类在其他文件中:
from classfile import MyClass
class MySubclass(MyClass):
def firstFunc(self, a, b):
c = a + b
d = self.secondFunc(self, c)
return d
def secondFunc(self, c):
d = c / 2
return d
这是一个愚蠢的例子,但它代表了我正在努力做的事情。
我想从第一个函数内的子类调用第二个函数。
但是,当我这样做时,它返回一个错误,表明MyClass没有这样的功能。
所以我想我在调用它时不应该在函数名前面使用self
。但是当我不这样做时,它也会引发错误。
所以我的问题是: 如何在子类的第一个函数中访问第二个函数?
编辑:
谢谢大家的帮助。我会更好地解释我正在尝试做什么,而我猜我的实现在代码中真的很糟糕。 MyClass是代码的主要类,其中包含所有小部件和主要功能。 此类上还有一个按钮,该按钮与“测试”功能绑定。因此,当按下按钮时,整个过程应该起作用。 MySubClass文件是一个将数据导出到某个文件的辅助模块。 firstFunc是此模块中的主要功能,它处理所有数据,而secondFunc只是构建文件的模板。所以我在firstFunc中调用了这个secondFunc,以便加载模板,然后将数据写入文件中。 我将此MySubClass继承自MyClass,以便它可以直接从MyClass访问数据库和其他变量。
所以我想我可以做到这一点。但我对这种实现并不十分熟悉。还有,抱歉我的英语不好。
答案 0 :(得分:2)
变化:
d = self.secondFunc(self, c)
要:
d = self.secondFunc(c)
答案 1 :(得分:2)
您不会从MyClass
的实例调用此方法,您可以从MySubclass
的实例调用它。问题是你可能得到一个TypeError
,因为你传递给firstFunc
的论证(自我)是错误的类型(MyClass
而不是MySubClass
) 。解决方案是重构您的代码,这样就不会发生。至少,我认为这是问题(当我尝试你的代码时,我得到了各种各样的导入错误)。这是我尝试的代码(我假设你说明了你所描述的问题):
class MyClass(object):
def uiFunc(self, MainWindow):
self.attr1 = "foo"
self.attr2 = "bar"
def test(self):
return MySubClass.firstFunc(self, 2, 2)
class MySubClass(MyClass):
def firstFunc(self, a, b):
c = a + b
d = self.secondFunc(c) #removed self from parameter list
return d
def secondFunc(self, c):
d = c / 2
return d
a=MyClass()
b=MySubClass()
print (b.test()) #this works because b is the right type to pass to first/second func
a.test() #This doesn't work because a is the wrong type.
请注意,将test
作为MyClass
的方法并不合理,因为无法>>从那里使用它。您也可以将test
移至MySubClass
。
另外,正如其他人所说,self.secondfunc(self,c)
也很奇怪。这基本等同于MySubClass.secondfunc(self,self,c)
,其参数数量错误,因为您传递self
两次。
这有效:
class MyClass(object):
def uiFunc(self, MainWindow):
self.attr1 = "foo"
self.attr2 = "bar"
def test(self):
return firstFunc(self, 2, 2)
def firstFunc(self, a, b):
c = a + b
d = secondFunc(self,c) #self from in front of function, now in parameter list
return d
def secondFunc(self, c):
d = c / 2
return d
class MySubClass(MyClass):
firstFunc=firstFunc
secondFunc=secondFunc
a=MyClass()
b=MySubClass()
print (b.test())
print (a.test())
但我强烈建议您重新构建代码。
答案 2 :(得分:1)
当你是一个实例方法时,你试图调用firstFunc
,就好像它是一个静态方法一样。您可以使用classmethod
装饰器来实现静态方法效果。