1

我有几十节课。这是其中的两个:

class Class_A(ClassABC):

    def __init__(self):
        super().__init__()

    def from_B(self, b):
        #do stuff

    def from_C(self, c):
        #do stuff

    #...

    def to_B(self):
        rt = Class_B()
        rt.from_A(self)
        return rt

    def to_C(self):
        rt = Class_C()
        rt.from_A(self)
        return rt

    #...

class Class_B(ClassABC):

    def __init__(self):
        super().__init__()

    def from_A(self, a):
        #do stuff

    def from_C(self, c):
        #do stuff

    def to_A(self):
        rt = Class_A()
        rt.from_B(self)
        return rt

    def to_C(self):
        rt = Class_C()
        rt.from_B(self)
        return rt

    #...

 #class Class_C, Class_D, Class_E, etc,

这是ABC:

class ClassABC(metaclass=abc.ABCMeta):

    @abc.abstractmethod
    def __init__(self):
        #do stuff

我遇到的问题是子类中的所有to_*方法都遵循相同的模式,实现它们变得乏味。如果可能的话,我想自动生成它们ClassABC,但到目前为止我失败了。我还尝试为子类创建一个类装饰器,但这也不起作用。然而,我已经设法使用 exec() 自动生成每个子类中的方法,但我宁愿让 ABC 生成它们或使用类装饰器。有没有办法做到这一点?

注意:所有类都在它们自己的单独模块中

4

1 回答 1

0

首先,您的to_*方法将不起作用,因为您需要self在参数列表的开头显式包含才能在方法主体中使用它。其次,我会采用类似于 JBernardo 的建议的方法。

def to_class(self, cls):
    rt = cls()
    rt.from_class(self.__class__)
    return rt

def from_class(self, cls):
    #do stuff, with different things happening based on what class cls is; this may be a good place to use a dict of functions with the class or classname as keys
于 2011-08-10T02:43:32.643 回答