编写类时,并非总是从空白开始。如果你编写的类是另一个现成类的特殊版本,可使用继承。
一个类继承另一个类时 ,它将自动获得另一个类的所有属性和方法;原有的类称为父类,而新类称为子类。
子类继承了其父类的所有属性和方法,同时还可以定义自己的属性和方法。
1、子类的方法__init__()
创建子类的实例时,python首先需要完成的任务是父类的所有属性赋值。为此,子类的方法__init__()需要父类施以援手。例如下边的BidDog示例。大狗是一种特殊的狗,因此我们可以在创建Dog的基础上创建新的类BigDog,这样我们只需要为BigDog特有的属性和行为编写代码。
示例代码1:
class Dog():
"""一次模拟小狗的简单尝试"""
def __init__(self, name, age):
"""初始化属性name和age"""
self.name = name
self.age = age
def sit(self):
"""模拟小狗被命令时蹲下"""
print(self.name.title() + " is now sitting.")
def roll_over(self):
"""模拟小狗被命令时打滚"""
print(self.name.title() + " rolled over!")
class BigDog(Dog):
"""big dog's special"""
def __init__(self, name, age): """初始化父类的属性"""
super().__init__(name, age)
my_dog = BigDog('willie', 6)
print("My dog's name is "+my_dog.name.title()+".")
print("My dog is " + str(my_dog.age)+" years old.
")
my_dog.sit()
my_dog.roll_over()
结果:
说明:
1、首先是Dog类的代码。创建子类时,父类必须包含在当前文件中,且位于子类前面。
2、定义子类时,必须在括号内指定父类的名称。方法__init__()接收拆功能键Dog实例所需的信息。
3、Super()是一个特殊函数,帮助Python将父类和子类关联起来。这行代码让Python调用BigDog的父类的方法__init()__,让BigDogbao实例包含父类的所有属性。父类也称为超类;
上述示例只是让BigDog具有了Dog的属性,接下来我们开始编写BigDog的属性和方法;
示例代码2增加了一个属性和一个特有的方法:
class Dog():
"""一次模拟小狗的简单尝试"""
def __init__(self, name, age):
"""初始化属性name和age"""
self.name = name
self.age = age
def sit(self):
"""模拟小狗被命令时蹲下"""
print(self.name.title() + " is now sitting.")
def roll_over(self):
"""模拟小狗被命令时打滚"""
print(self.name.title() + " rolled over!")
class BigDog(Dog):
"""big dog's special"""
def __init__(self, name, age):
super().__init__(name, age)
self.length = 100
def describe_length(self):
print("The BigDog's length is "+str(self.length)+" km")
my_dog = BigDog('willie', 6)
print("My dog's name is "+my_dog.name.title()+".")
print("My dog is " + str(my_dog.age)+" years old.
")
my_dog.sit()
my_dog.roll_over()
my_dog.describe_length()
输出结果:
==========进阶===========
1、重写父类的方法:
对于父类的方法,只要它不符合子类模拟的实物的行为,都可对其进行重写。
为此,可在子类中创建一个这样的方法,即它与要重写的父类方法同名。这样python将不会考虑吧这个父类方法,而只是关注你在子类中定义的相应方法。
2、将实例用作属性
使用代码模拟实物时,你可能会发现自己给类添加的细节越来越多:属性和方法清单以及文件越来越长。在这种情况下,可能需要将类的一部分作为一个独立的类提取出来。你可以将大型类拆分成多个协同工作的小类。
比如针对狗的毛的描述可能有很多的属性,所以可以将毛作为一个类
class Mao():
def __init__(self, color="yello")
self.color = colors
def describe_color(self):
print("The color is "+self.color)
class Dog():
"""一次模拟小狗的简单尝试"""
def __init__(self, name, age):
"""初始化属性name和age"""
self.name = name
self.age = age
def sit(self):
"""模拟小狗被命令时蹲下"""
print(self.name.title() + " is now sitting.")
def roll_over(self):
"""模拟小狗被命令时打滚"""
print(self.name.title() + " rolled over!")
class BigDog(Dog):
"""big dog's special"""
def __init__(self, name, age):
super().__init__(name, age)
self.length = 100
self.mao = Mao()
def describe_length(self):
print("The BigDog's length is "+str(self.length)+" km")
my_dog = BigDog('willie', 6)
print("My dog's name is "+my_dog.name.title()+".")
print("My dog is " + str(my_dog.age)+" years old.
")
my_dog.sit()
my_dog.roll_over()
my_dog.describe_length()
my_dog.mao.describe_color()
结果显示: