3

假设我有这个类:

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 访问数据库和其他变量。

所以我想我可以这样做。但我对这种实现并不真正有经验。另外,对不起我的英语不好。

4

3 回答 3

2

改变:

d = self.secondFunc(self, c)

到:

d = self.secondFunc(c)
于 2012-06-18T12:37:27.893 回答
2

您不会从 的实例调用此方法MyClass,而是从 的实例调用它MySubclass。问题是您可能会得到一个TypeError,因为您传递给的参数(self)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)which 有错误数量的参数,因为你传递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())

但我强烈建议重构您的代码。

于 2012-06-18T12:41:55.320 回答
1

firstFunc当它是实例方法时,您试图将其作为静态方法调用。可以使用classmethod装饰器来实现静态方法效果。

于 2012-06-18T12:37:51.970 回答