Python编程基础:面向对象编程

简介: 巩固Python面向对象编程一些基础知识,学习有关类的创建使用,以及类的属性方法使用等一些基础操作。

一、前言

本期博客,我们将了解学习Python面向对象编程的相关知识,学习如何编写类和使用类等一系列操作。

二、我的环境

  • 电脑系统:Windows 11
  • 语言版本:Python 3.10.4
  • 编译器:VSCode

三、创建和使用类

我们在使用类时几乎可以模拟现实世界中的任何东西,接下来我们创建一个简单的Dog类来表示所有的小狗,并为它定义属性和行为。

1、创建Dog类

classDog:
"""模拟小狗"""def__init__(self, name, age):
"""初始化小狗属性"""self.name=nameself.age=agedefsit(self):
"""模拟小狗蹲下"""print(f"小狗{self.name}已经蹲下了。")
defroll_over(self):
"""模拟小狗打滚"""print(f"小狗{self.name}正在打滚。")

其中__init__()方法是一个特殊的方法,后续每当我们使用该类创建新实例的时候Python会自动运行该方法,在这个方法中形参self必不可少,而且必须位于其他形参的前面,每个与实例相关联的方法调用都会自动传递实参self,它是一个指向实例本身的引用,让实例能够访问类中的属性和方法。

2、根据类创建实例

接下来我们将根据之前创建的类创建一个实例:

my_dog=Dog("哈里", 3)
print(f"我的小狗叫{my_dog.name}。")
print(f"我的小狗今年{my_dog.age}岁了。")
my_dog.sit()
my_dog.roll_over()

它运行的结果是:

我的小狗叫哈里。我的小狗今年3岁了。小狗哈里已经蹲下了。小狗哈里正在打滚。

如果我们要访问类的属性需要使用“实例.属性”格式,例如上面我们访问小狗的名字my_dog.name。

如果我们要调用类的方法需要使用“实例.方法”格式,例如上面我们让小狗蹲下my_dog.sit()。

我们也可以创建多个实例,并且每个实例都有自己的一组属性,能够执行相同的操作:

my_dog=Dog("哈里", 3)
print(f"我的小狗叫{my_dog.name}。")
print(f"我的小狗今年{my_dog.age}岁了。")
my_dog.sit()
your_dog=Dog("卢斯", 4)
print(f"你的小狗叫{your_dog.name}。")
print(f"你的小狗今年{your_dog.age}岁了。")
your_dog.sit()

它运行的结果是:

我的小狗叫哈里。我的小狗今年3岁了。小狗哈里已经蹲下了。你的小狗叫卢斯。你的小狗今年4岁了。小狗卢斯已经蹲下了。

四、使用类和实例

我们还可以使用类来模拟现实世界中的很多情景,当我们的类编写好之后,我们就可以将时间花在根据类创建的实例上。

1、创建Car类

classCar:
"""模拟汽车"""def__init__(self, make, model, year):
"""初始化描述汽车的属性"""self.make=makeself.model=modelself.year=yeardefget_descriptive_name(self):
"""返回整洁的描述信息"""long_name=f"{self.year}{self.make}{self.model}"returnlong_name.title()
my_new_car=Car("audi", 'a4', 2022)
print(my_new_car.get_descriptive_name())

它运行的结果是:

2022AudiA4

2、给属性指定默认值

我们在创建实例时,有些属性无须通过形参来定义,我们可以指定默认值,例如我们添加一个odometer_reading的属性,其初始值为0,然后我们在添加一个read_odometer()方法,用于读取汽车的里程表:

classCar:
"""模拟汽车"""def__init__(self, make, model, year):
"""初始化描述汽车的属性"""self.make=makeself.model=modelself.year=yearself.odometer_reading=0defget_descriptive_name(self):
"""返回整洁的描述信息"""long_name=f"{self.year}{self.make}{self.model}"returnlong_name.title()
defread_odometer(self):
"""打印汽车里程表信息"""print(f"这辆车已经跑了{self.odometer_reading}公里了。")
my_new_car=Car("audi", 'a4', 2022)
print(my_new_car.get_descriptive_name())
my_new_car.read_odometer()

它运行的结果是:

2022AudiA4这辆车已经跑了0公里了。

3、修改属性值

新车的里程为0很正常,但随着开车,里程不可能一直为0,所以我们还需要定义一个可以修改属性的方法,下面介绍三种方法。

  • 直接修改属性的值
    这是最简单的方法在调用方法前指定属性值为多少。
my_new_car=Car("audi", 'a4', 2022)
print(my_new_car.get_descriptive_name())
my_new_car.odometer_reading=23my_new_car.read_odometer()
  • 它运行的结果是:
2022AudiA4这辆车已经跑了23公里了。
  • 这种方法简单,但非常不实用,因为我们可以随便定义里程,这不符合实际情况。
  • 通过方法修改属性的值
    定义一个方法,让其在内部更新,并且为其定义逻辑禁止将里程表读数往回调。
classCar:
--snip--defupdate_odometer(self, mileage):
"""将里程表读数设置为指定的值"""ifmileage>=self.odometer_reading:
self.odometer_reading=mileageelse:
print("你不能输入比之前里程数更低的数!")
--snip--my_new_car=Car("audi", 'a4', 2022)
print(my_new_car.get_descriptive_name())
my_new_car.update_odometer(23)
my_new_car.read_odometer()
  • 结果跟之前的一样,但添加了新逻辑判断。
  • 通过方法对属性的值进行递增
    有时候需要将属性值递增特定的量,而不是将其设置为全新的值。假设我们购买了一辆二手车,且从购买到登记期间增加了100英里的里程。下面的方法让我们能够传递这个增量,并相应地增大里程表读数。
classCar:
--snip--defupdate_odometer(self, mileage):
"""将里程表读数设置为指定的值"""ifmileage>=self.odometer_reading:
self.odometer_reading=mileageelse:
print("你不能输入比之前里程数更低的数!")
defincrement_odometer(self,miles):
self.odometer_reading+=miles--snip--my_used_car=Car("audi", 'a4', 2022)
print(my_used_car.get_descriptive_name())
my_used_car.update_odometer(23_500)
my_used_car.read_odometer()
my_used_car.increment_odometer(100)
my_used_car.read_odometer()
  • 运行的结果是:
2022AudiA4这辆车已经跑了23500公里了。这辆车已经跑了23600公里了。

五、继承

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

1、子类的方法__init__()

在既有类的基础上编写新类时,通常要调用父类的方法__init__(),从而让子类也包含这些属性。

下面我们在之前的Car类下再创建一个ElectricCar类,它具备Car类的所有功能。

classCar:
"""模拟汽车"""def__init__(self, make, model, year):
"""初始化描述汽车的属性"""self.make=makeself.model=modelself.year=yearself.odometer_reading=0defget_descriptive_name(self):
"""返回整洁的描述信息"""long_name=f"{self.year}{self.make}{self.model}"returnlong_name.title()
defupdate_odometer(self, mileage):
"""将里程表读数设置为指定的值"""ifmileage>=self.odometer_reading:
self.odometer_reading=mileageelse:
print("你不能输入比之前里程数更低的数!")
defincrement_odometer(self,miles):
self.odometer_reading+=milesdefread_odometer(self):
"""打印汽车里程表信息"""print(f"这辆车已经跑了{self.odometer_reading}公里了。")
classElectricCar(Car):
""""电动车的独特之处"""def__init__(self, make, model, year):
""""初始化父类的属性"""super().__init__(make, model, year)
my_tesla=ElectricCar('tesla','models', '2022')
print(my_tesla.get_descriptive_name())


它运行的结果是:

2022TeslaModels

在创建子类时,父类必须包含在当前文件中,且位于子类的前面。

子类中的super()是一种特殊的函数,可以让我们能够调用父类的方法。

2、给子类定义属性和方法

让一个类继承另一个类后,就可以添加区分子类和父类所需的新属性和新方法了。

下面我们将给电动车添加新属性以及一个描述该属性的方法。

classElectricCar(Car):
""""电动车的独特之处"""def__init__(self, make, model, year):
""""先初始化父类的属性,再初始化电动车特有属性"""super().__init__(make, model, year)
self.battery_size=75defdescribe_battery(self):
"""打印描述电瓶容量的消息"""print(f"这个电动车电瓶容量为{self.battery_size}kwh。")
my_tesla=ElectricCar('tesla','models', '2022')
print(my_tesla.get_descriptive_name())
my_tesla.describe_battery()

它运行的结果是:

2022TeslaModels这个电动车电瓶容量为75kwh。

模拟电动汽车时,可根据所需的准确程度添加任意数量的属性和方法。如果一个属性或方法是任何汽车都有的,而不是电动汽车特有的,就应将其加入到Car类而非ElectricCar类中。这样,使用Car类的人将获得相应的功能,而ElectricCar类只包含处理电动汽车特有属性和行为的代码。

3、重写父类的方法

对于父类,只要它不符合子类模拟的实物的行为就可以进行重写,我们只需要再子类中定义一个与要重写的父类方法同名的方法即可。

4、将实例用作属性

使用代码模拟实物时,你可能会发现自己给类添加的细节越来越多:属性和方法清单以及文件都越来越长。在这种情况下,可能需要将类的一部分提取出来,作为一个独立的类。可以将大型类拆分成多个协同工作的小类。

例如我们可以专门定义一个Battery类,将针对汽车电瓶的属性和方法提取出来。

classBattery:
"""模拟电动车电瓶"""def__init__(self, battery_size=75):
"""初始化电瓶的属性"""self.battery_size=battery_sizedefdescribe_battery(self):
"""打印描述电瓶容量的消息"""print(f"这个电动车电瓶容量为{self.battery_size}kwh。")
classElectricCar(Car):
""""电动车的独特之处"""def__init__(self, make, model, year):
""""先初始化父类的属性,再初始化电动车特有属性"""super().__init__(make, model, year)
self.battery=Battery()
my_tesla=ElectricCar('tesla','models', '2022')
print(my_tesla.get_descriptive_name())
my_tesla.battery.describe_battery()

它运行的结果是:

2022TeslaModels这个电动车电瓶容量为75kwh。

输出结果和之前一样,我们将电瓶和电动车分开,这样看似很麻烦要做很多额外的工作,但可以让我们更加专注于描述某一类,并且也更好的专门添加功能和修改。

六、最后我想说

本期的Python面向对象编程内容就到此为止了,内容也不是很多,总结的也比较粗略,想要学习更多有关这方面的知识可以多去看看相关书籍或者其他大佬的博客。

有关Python编程基础的内容更新也差不多结束了,后续更新可能就是具体的练习题目或者具体的问题解决。

最后,谢谢大家能阅读完,我也希望能得到大家的支持和肯定,谢谢!

北天
+关注
目录
打赏
0
0
0
0
300
分享
相关文章
探索Python编程:从基础到高级
在这篇文章中,我们将一起深入探索Python编程的世界。无论你是初学者还是有经验的程序员,都可以从中获得新的知识和技能。我们将从Python的基础语法开始,然后逐步过渡到更复杂的主题,如面向对象编程、异常处理和模块使用。最后,我们将通过一些实际的代码示例,来展示如何应用这些知识解决实际问题。让我们一起开启Python编程的旅程吧!
Python编程入门:从零基础到实战应用
本文是一篇面向初学者的Python编程教程,旨在帮助读者从零开始学习Python编程语言。文章首先介绍了Python的基本概念和特点,然后通过一个简单的例子展示了如何编写Python代码。接下来,文章详细介绍了Python的数据类型、变量、运算符、控制结构、函数等基本语法知识。最后,文章通过一个实战项目——制作一个简单的计算器程序,帮助读者巩固所学知识并提高编程技能。
[oeasy]python053_学编程为什么从hello_world_开始
视频介绍了“Hello World”程序的由来及其在编程中的重要性。从贝尔实验室诞生的Unix系统和C语言说起,讲述了“Hello World”作为经典示例的起源和流传过程。文章还探讨了C语言对其他编程语言的影响,以及它在系统编程中的地位。最后总结了“Hello World”、print、小括号和双引号等编程概念的来源。
112 80
Python编程数据结构的深入理解
深入理解 Python 中的数据结构是提高编程能力的重要途径。通过合理选择和使用数据结构,可以提高程序的效率和质量
161 59
|
20天前
|
[oeasy]python055_python编程_容易出现的问题_函数名的重新赋值_print_int
本文介绍了Python编程中容易出现的问题,特别是函数名、类名和模块名的重新赋值。通过具体示例展示了将内建函数(如`print`、`int`、`max`)或模块名(如`os`)重新赋值为其他类型后,会导致原有功能失效。例如,将`print`赋值为整数后,无法再用其输出内容;将`int`赋值为整数后,无法再进行类型转换。重新赋值后,这些名称失去了原有的功能,可能导致程序错误。总结指出,已有的函数名、类名和模块名不适合覆盖赋新值,否则会失去原有功能。如果需要使用类似的变量名,建议采用其他命名方式以避免冲突。
37 14
技术评测:MaxCompute MaxFrame——阿里云自研分布式计算框架的Python编程接口
随着大数据和人工智能技术的发展,数据处理的需求日益增长。阿里云推出的MaxCompute MaxFrame(简称“MaxFrame”)是一个专为Python开发者设计的分布式计算框架,它不仅支持Python编程接口,还能直接利用MaxCompute的云原生大数据计算资源和服务。本文将通过一系列最佳实践测评,探讨MaxFrame在分布式Pandas处理以及大语言模型数据处理场景中的表现,并分析其在实际工作中的应用潜力。
78 2
探索Python编程:从基础到实战
本文将引导你走进Python编程的世界,从基础语法开始,逐步深入到实战项目。我们将一起探讨如何在编程中发挥创意,解决问题,并分享一些实用的技巧和心得。无论你是编程新手还是有一定经验的开发者,这篇文章都将为你提供有价值的参考。让我们一起开启Python编程的探索之旅吧!
55 10
Python 语言:强大、灵活与高效的编程之选
本文全面介绍了 Python 编程语言,涵盖其历史、特点、应用领域及核心概念。从 1989 年由 Guido van Rossum 创立至今,Python 凭借简洁的语法和强大的功能,成为数据科学、AI、Web 开发等领域的首选语言。文章还详细探讨了 Python 的语法基础、数据结构、面向对象编程等内容,旨在帮助读者深入了解并有效利用 Python 进行编程。
探索Python编程的奥秘
在数字世界的海洋中,Python如同一艘灵活的帆船,引领着无数探险者穿梭于数据的波涛之中。本文将带你领略Python编程的魅力,从基础语法到实际应用,一步步揭开Python的神秘面纱。
48 12
Python编程入门:打造你的第一个程序
迈出编程的第一步,就像在未知的海洋中航行。本文是你启航的指南针,带你了解Python这门语言的魅力所在,并手把手教你构建第一个属于自己的程序。从安装环境到编写代码,我们将一步步走过这段旅程。准备好了吗?让我们开始吧!
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等