如何根据参数指定应调用哪个__init__?

时间:2018-04-30 11:05:13

标签: python python-3.x class inheritance uml

所以我最近开始学习python,现在我遇到了一个我应该实现UML图的任务。 它看起来像这样:

UML Diagram

它基本上模拟人,成人,儿童和退休人员。现在,我被卡住的部分是,任务是一个参数,说“alter”(eng。= age)定义应该初始化哪个类。年龄低于18岁(改变<18)的人是一种(eng。=孩子)。 18到61岁之间的人是Erwachsener(eng。=成人),上面的所有人都是养老金领取者(eng。=退休人员)。

现在我的问题是我不知道如何实现这种区分......

这是我到目前为止所做的:

class Person:
    def __init__(self, name, male, alter):
        self.name = name
        self.male = male
        self.__alter = alter

    def print_beschreibung(self):
        if self.male:
            print("Ich heiße " + self.name + ", bin männlich,", self.__alter, "Jahre alt")
        else:
            print("Ich heiße " + self.name +  ", bin weiblich,", self.__alter, "Jahre alt")    

    def get_alter(self):
        return self.__alter    

    def set_alter(self, neues_alter):
        self.__alter = neues_alter

class Erwachsener(Person):
    def __init__(self, name, male, alter, lohn, ist_verheiratet, kinder):
        super().__init__(name, male, alter)
        self.__lohn = lohn
        self.ist_verheiratet = ist_verheiratet
        self.kinder = kinder    


peter = Person("Peter Lustig", True, 52)
peter.print_beschreibung()

1 个答案:

答案 0 :(得分:1)

有多种方法可以实现此行为。最简单的是让一个类_Person与您当前的Person类相同:

class _Person:
    def __init__(self, name, male, alter):
        self.name = name
        self.male = male
        self.__alter = alter

    def print_beschreibung(self):
        if self.male:
            print("Ich heiße " + self.name + ", bin männlich,", self.__alter, "Jahre alt")
        else:
            print("Ich heiße " + self.name + ", bin weiblich,", self.__alter, "Jahre alt")

    def get_alter(self):
        return self.__alter

    def set_alter(self, neues_alter):
        self.__alter = neues_alter


class Kind(_Person):
    pass


class Erwachsener(_Person):
    def __init__(self, name, male, alter, lohn, ist_verheiratet, kinder):
        super().__init__(name, male, alter)
        self.__lohn = lohn
        self.ist_verheiratet = ist_verheiratet
        self.kinder = kinder


class Pensionierter(_Person):
    pass

然后你有一个函数Person,它的行为类似于一个类,并返回一个相应的ErwachsenerKindPensionierter类:

def Person(*args, **kwargs):
    alter = args[2]
    if alter < 18:
        return Kind(*args, **kwargs)
    elif 18 <= alter <= 61:
        return Erwachsener(*args, **kwargs)
    else:
        return Pensionierter(*args, **kwargs)

然后您可以像这样使用此功能:

peter = Person("Peter Lustig", True, 52, 0, False, 0)
print(isinstance(peter, Erwachsener))
peter.print_beschreibung()

如果你希望Person成为一个班级,你将不得不做一些魔术:

class Person:
    def __new__(cls, *args, **kwargs):
        alter = args[2]
        if alter < 18:
            cls = Kind
        elif alter < 61:
            cls = Erwachsener
        else:
            cls = Pensionierter
        return object.__new__(cls)
     # The rest of the class

然后您可以按上述方式使用它:

peter = Person("Peter Lustig", True, 52,0,False,0)
print(isinstance(peter, Erwachsener)) # prints True
peter.print_beschreibung()

但你也可以这样:

print(isinstance(peter, Person)) # prints True