一个类继承另一个类时,会自动获得另一个类的所有属性和方法,被继承的类称之为父类,新类称为子类。子类拥有父类所有的属性和方法,并且可以定义自己的属性和方法。
首先我们定义一个表示动物的父类:
class Animal:
def __init__(self, animal_name, animal_type='animal'):
self.animal_type = animal_type
self.animal_name = animal_name
def eat(self):
print(self.animal_name + ':eat')
def walk(self):
print(self.animal_name + ':walk')
def run(self):
print(self.animal_name + ':run')
我们生成一个Animal实例并且输出它的所有属性和方法:
animal = Animal('动物','eat-animal')
print(animal.animal_name)
print(animal.animal_type)
animal.eat()
animal.walk()
animal.run()
运行结果:
动物
eat-animal
动物:eat
动物:walk
动物:run
好的,大家可以看到我们的类实例是正常的,没有任何问题。那么接下来我们就要,通过继承来创建我们的新类了。这里我们创建一个Birds类吧。
语法:
class Birds(Animal):
def __init__(self,animal_name,animal_type='birds'):
super().__init__(animal_name,animal_type)
在python2.7中大家可能会遇到这要的写法:
class Birds(Animal):
def __init__(self,animal_name,animal_type='birds'):
super(Birds,self).__init__(animal_name,animal_type)
这和上面的区别在于super这个特殊函数必须接收两个参数,第一个是子类名,第二个是对象self。
在创建子类的时候,首先我们的确保在当前文件中,你已经定义好了父类,而且父类定义的必须在子类前面。
定义子类的时候,必须在括号内指定父类的名称。init 函数接收创建实例的所需参数,注意一点:这里必须包括父类init 函数的参数。你也可以添加你自己的参数:
def __init__(self,animal_name,animal_type='birds',birds_age=10):
这里必须调用父类的 init 函数,这样才能让子类拥有父类的所有属性。
然后我们试着输出我们的子类:
bird = Birds('百灵鸟')
print(bird.animal_name)
print(bird.animal_type)
print(bird.birds_age)
bird.eat()
bird.walk()
bird.run()
运行结果:
百灵鸟
birds
10
百灵鸟:eat
百灵鸟:walk
百灵鸟:run
我们继承父类,不会只想像上面一样这样的简单使用吧,我们当然希望能在我们的子类中增加我们需要的属性和方法。
还是拿上面的例子来说,我们给Birds类增加一个标识有几只腿的属性和一个飞的方法。
class Birds(Animal):
def __init__(self,animal_name,animal_type='birds'):
super().__init__(animal_name,animal_type)
self.leg_count = 2
def fly(self):
print(self.animal_name + ':fly')
print('此鸟有'+ str(self.leg_count) +'只腿')
添加属性和方法和我们前面讲过的一样,没什么需要注意的。我们调用以下fly方法,看下能否正常输出:
bird = Birds('百灵鸟')
print(bird.leg_count)
bird.fly()
输出:
2
百灵鸟:fly
此鸟有2只腿
在子类中,父类的方法有可能不符合我们的期望,此时,我们需要重写父类的方法,来实现子类特性。拿Birds来说,我们希望它可以在eat方法中增加一行输出,比如我是一只吃素的鸟,显然,我们要重写eat方法:
def eat(self):
super().eat()
print("我是一只吃素的鸟")
然后调用一下eat方法:
bird.eat()
输出:
百灵鸟:eat
我是一只吃素的鸟
这里大家可能看到我调用了父类的eat方法,这里我只是增加一行输出,父类的输出我们还是需要的,所以会调用。如果子类的方法和父类的逻辑不同,千万不要在调用父类的方法,自己重新实现就好。
最后我们在来聊一下类的嵌套使用,这里的嵌套值得是将一个类作为另一个类的属性。
让我们看下语法示例:
class Food:
def __init__(self):
self.favorite_food = 'banana'
class Person:
def __init__(self):
self.food = Food()
def show_favorite(self):
print("My favorite food is :" + self.food.favorite_food.title())
person = Person();
person.show_favorite()
例子如上,很简单,首先我们定义好food类,然后将food类作为person类的属性,使用和普通的属性没有区别,只不过这个属性还可以调用自身的方法。
输出:
My favorite food is :Banana