Python 中访问父类属性

要访问子类中的父类属性:

  1. 使用 super() 方法在 child 中调用 parent 的构造函数。
  2. __init__() 方法将设置实例变量。
  3. 访问 self 对象上的任何父类的属性或方法。
class Employee():
    cls_id = 'emp-cls'

    def __init__(self, name):
        self.salary = 100
        self.name = name


class Developer(Employee):
    def __init__(self, name):
        # ?️ invoke parent __init__() method
        super().__init__(name)

        # ?️ accessing parent instance variable
        print(self.salary)  # ?️ 100

        # ?️ accessing parent class variable
        print(self.cls_id)  # ?️ emp-cls


d1 = Developer('zadmei')
print(d1.salary)  # ?️ 100

print(d1.cls_id)  # ?️ 'emp-cls'

上述代码运行结果如下:

Python 中访问父类属性

代码片段显示了如何从子类访问父类变量和父实例变量。

cls_id 属性是一个类变量。

可以直接在子实例或子类本身上访问类变量。

class Employee():
    cls_id = 'emp-cls'


class Developer(Employee):
    def __init__(self, name):

        # ?️ 获取父类变量
        print(self.cls_id)  # ?️ emp-cls


d1 = Developer('bobbyhadz')

print(d1.cls_id)  # ?️ 'emp-cls'
print(Developer.cls_id)  # ?️ 'emp-cls'

要访问父实例变量,请调用类的构造方法来运行父类的 __init__() 方法中的代码。

class Employee():
    def __init__(self, name):
        self.salary = 100
        self.name = name


class Developer(Employee):
    def __init__(self, name):
        # ?️ call parent __init__() method
        super().__init__(name)

        print(self.salary)  # ?️ 100


d1 = Developer('zadmei')
print(d1.salary)  # ?️ 100

super() 方法使我们无需显式引用即可访问基类。

我们可以用 Employee 替换对 super() 的调用以达到相同的结果。

class Employee():
    def __init__(self, name):
        self.salary = 100
        self.name = name


class Developer(Employee):
    def __init__(self, name):
        Employee.__init__(self, name)

        print(self.salary)  # ?️ 100


d1 = Developer('zadmei')
print(d1.salary)  # ?️ 100

但是,与显式引用基类相比,super() 更灵活且更常用。

对父级的 __init__ 方法的调用运行该方法并将薪水和姓名属性分配给实例。

现在我们可以在子类的实例上访问父类的 salary 和 name 属性。

示例中的类假定需要一个名称参数。

这是相同的示例,但在实例化子类时没有传递任何参数。

**class Employee():
    def __init__(self):
        self.salary = 100


class Developer(Employee):
    def __init__(self):
        super().__init__()

        print(self.salary)  # ?️ 100


d1 = Developer()
print(d1.salary)  # ?️ 100

一旦父级的 __init__() 方法中的代码运行,实例就会被分配一个 salary 属性,可以在 self 对象上访问该属性。

我们可以使用相同的方法从子类访问父类中定义的方法。

class Employee():
    def __init__(self, name):
        self.salary = 100
        self.name = name

    def greet(self):
        print(f'Hello {self.name}')


class Developer(Employee):
    def __init__(self, name):
        super().__init__(name)

        print(self.salary)  # ?️ 100

        self.greet()  # ?️ Hello bobbyhadz


d1 = Developer('zadmei')
print(d1.salary)  # ?️ 100

d1.greet()  # ?️ Hello zadmei

父对象定义了一个 greet() 方法,子实例可以通过 self 对象访问该方法。