# 父类(基类)
class Student:
def __init__(self, name, score):
self.name = name
self.score = score
def get_grade(self):
if
90 <= self.score <= 100:
return
'A'
else
:
return
'B'
def learning(self):
print(
'每天早上8:00-18:00开始学习'
)
# 子类ComputerStudent继承Student父类
class ComputerStudent(Student):
def get_grade(self):
if
70 <= self.score <= 100:
return
'A'
else
:
return
'B'
def learning(self):
# 3). 调用父类的方法:找到ComputerStudent的父类,执行父类的learning方法
super
(ComputerStudent, self).learning()
print(
' - 操作系统'
)
print(
' - 计算机网络'
)
print(
' - 计算机组成'
)
print(
' - 数据结构与算法'
)
# 子类MathStudent继承Student父类
class MathStudent(Student):
def learning(self):
# 3).调用父类的方法:找到MathStudent的父类,执行父类的learning方法
super
(MathStudent, self).learning()
print(
' - 高等数学'
)
print(
' - 线性代数'
)
# s = Student('张三', 100)
# print(s.name, s.score, s.get_grade())
# 1). 继承规则: 自己有get_grade方法执行自己的get_grade方法
s1 = ComputerStudent(
'李四'
, 80)
print(s1.get_grade())
# A
s1.learning()
# print(s1.aa()) # 不会执行
# 2). 继承规则: 自己没有get_grade方法执行父类的get_grade方法
s2 = MathStudent(
'张三'
, 80)
print(s2.get_grade())
# B
# print(s1.aa()) # 不会执行
s2.learning()