Python 中访问父类属性
要访问子类中的父类属性:
- 使用 super() 方法在 child 中调用 parent 的构造函数。
- __init__() 方法将设置实例变量。
- 访问 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'
上述代码运行结果如下:
代码片段显示了如何从子类访问父类变量和父实例变量。
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 对象访问该方法。
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布,任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站。本站所有源码与软件均为原作者提供,仅供学习和研究使用。如您对本站的相关版权有任何异议,或者认为侵犯了您的合法权益,请及时通知我们处理。