问题描述
我正在尝试编写一个基本抽象类,该类具有一些将使用构造函数初始化的属性。到目前为止,我有这个:
from abc import ABC,abstractmethod
class A(ABC):
def __init__(self,n,*params):
self.n = n
self.initialize_params(*params) #I want to do this in all subsclasses of A
def initialize_params(self,*params)
pass
@abstractmethod
def do(self):
pass
class B(A):
def __init__(self,m,*super_params):
self.m = m
super(A,self).__init__(n,*super_params)
def do(self):
print("this is B")
但是这会抛出 TypeError
因为 A 在 B 的 __init__
中的实例化。这样做的正确方法是什么?
解决方法
你似乎有几个错误:
from abc import ABC,abstractmethod
class A(ABC):
def __init__(self,n,*params):
self.n = n
self.initialize_params(*params) #I want to do this in all subsclasses of A
def initialize_params(self,*params):
pass
@abstractmethod
def do(self):
pass
class B(A):
def __init__(self,m,*super_params):
self.m = m
super().__init__(n,*super_params) # correct way to use super() to call init
def do(self):
print("this is B")
b = B(1,2)
b.do()
请注意,您错过了 self.
前面的 initialize_params()
,而且您似乎没有正确使用 super()
。