初识Python之面向对象编程之继承

自己弄了一个python学习群,感兴趣的可以加在这里插入图片描述

编写类时,并非总是要从空白开始。如果你要编写的类是另一个现成类的特殊版本,可使用继承
一个类继承另一个类时,它将自动获得另一个类的所有属性和方法
原有的类称为父类,而新类称为子类。子类继承了其父类的所有属性和方法,同时还可以定义自己的属性和方法

例子来源于Python编程: 从入门到实践

electric_car.py

class Car():
    # 一次模拟汽车的简单尝试

    def __init__(self, make, model, year):
        self.make = make
        self.model = model
        self.year = year
        self.odometer_reading = 0

    def get_descriptive_name(self):
        long_name = str(self.year) + ' ' + self.make + ' ' + self.model
        return long_name.title()

    def read_odometer(self):
        print("This car has " + str(self.odometer_reading) + " miles on it.")

    def update_odometer(self, mileage):
        if mileage >= self.odometer_reading:
            self.odometer_reading = mileage
        else:
            print("You can't roll back an odometer!")

    def increment_odometer(self, miles):
        self.odometer_reading += miles

ElectricCar.py

from electric_car import Car


class ElectricCar(Car):

    # 电动汽车的独特之处
    def __init__(self, make, model, year):
        # 初始化父类的属性
        super().__init__(make, model, year)


my_tesla = ElectricCar('tesla', 'model s', 2016)
print(my_tesla.get_descriptive_name())

运行ElectricCar.py

2016 Tesla Model S

那如果我们不想用父类的方法呢?

子类也会有特定的方法,那就是把父类的重写

from electric_car import Car


class ElectricCar(Car):

    # 电动汽车的独特之处
    def __init__(self, make, model, year):
        # 初始化父类的属性
        super().__init__(make, model, year)

    def get_descriptive_name(self):
        long_name = str(self.year) + ' ' + self.make + ' this is son method '
        return long_name.title()


my_tesla = ElectricCar('tesla', 'model s', 2016)
print(my_tesla.get_descriptive_name())

这样运行的就是子类的方法

2016 Tesla This Is Son Method 

同样的在子类中还可以拓展更多的父类没有的方法和属性

from electric_car import Car


class ElectricCar(Car):

    # 电动汽车的独特之处
    def __init__(self, make, model, year):
        # 初始化父类的属性
        super().__init__(make, model, year)
        # 初始化电动汽车的特有属性
        self.battery_size = 70

    def get_descriptive_name(self):
        long_name = str(self.year) + ' ' + self.make + ' this is son method '
        return long_name.title()

    # 子类特有的方法
    def son_method(self):
        son_message = str(self.battery_size) + ' you are right, this is son param '
        return son_message.title()


my_tesla = ElectricCar('tesla', 'model s', 2016)
print(my_tesla.get_descriptive_name())
print(my_tesla.son_method())

运行子类就是:

2016 Tesla This Is Son Method 
70 You Are Right, This Is Son Param 

同样的,我们也可以将一个实例用作属性:

Battery.py

class Battery():
    """一次模拟电动汽车电瓶的简单尝试"""

    def __init__(self, battery_size=70):
        """初始化电瓶的属性"""
        self.battery_size = battery_size

    def describe_battery(self):
        """打印一条描述电瓶容量的消息"""
        print("This car has a " + str(self.battery_size) + "-kWh battery.")

ElectricCar.py

from electric_car import Car
from Battery import Battery


class ElectricCar(Car):

    # 电动汽车的独特之处
    def __init__(self, make, model, year):
        # 初始化父类的属性
        super().__init__(make, model, year)
        # 初始化电动汽车的特有属性
        self.battery_size = 70
        self.battery = Battery()

    def get_descriptive_name(self):
        long_name = str(self.year) + ' ' + self.make + ' this is son method '
        return long_name.title()

    # 子类特有的方法
    def son_method(self):
        son_message = str(self.battery_size) + ' you are right, this is son param '
        return son_message.title()


my_tesla = ElectricCar('tesla', 'model s', 2016)
print(my_tesla.get_descriptive_name())
print(my_tesla.son_method())
my_tesla.battery.describe_battery()

运行:

2016 Tesla This Is Son Method 
70 You Are Right, This Is Son Param 
This car has a 70-kWh battery.

勤加练习

拓展

你必须熟悉有些与类相关的编码风格问题,在你编写的程序较复杂时尤其如此。
类名应采用驼峰命名法,即将类名中的每个单词的首字母都大写,而不使用下划线。实例名 和模块名都采用小写格式,并在单词之间加上下划线。
对于每个类,都应紧跟在类定义后面包含一个文档字符串。这种文档字符串简要地描述类的
功能,并遵循编写函数的文档字符串时采用的格式约定。每个模块也都应包含一个文档字符串, 对其中的类可用于做什么进行描述。
可使用空行来组织代码,但不要滥用。在类中,可使用一个空行来分隔方法;而在模块中, 可使用两个空行来分隔类。
需要同时导入标准库中的模块和你编写的模块时,先编写导入标准库模块的import语句,再
添加一个空行,然后编写导入你自己编写的模块的import语句。在包含多条import语句的程序中,
这种做法让人更容易明白程序使用的各个模块都来自何方。


关注公众号:Python互助小组
一起学习,共同进步
里面有不定期的赠书活动哦
公众号:Python互助小组 或者搜索python_group

你可能感兴趣的:(Python基础)