学习python类的总结

前言

之前天天看到有人用类相关的知识但是学校老师就是没讲过,然后再读了莫烦老师的讲解后,有了一定的了解,进行一个总结。

正文

类的意义

类其实就是正如他的名字一样,是一类事物(其实叫做对象)的总称,就像学生信息,每个学生都是一个事物(对象),但是我们对每一个学生的信息都进行一个变量的输入的话,未免过于冗杂,就像下面

student1={'名字':'hh','年龄':19,'性别':'男'}
student2={'名字':'nn','年龄':20,'性别':'男'}
student3={'名字':'ww','年龄':20,'性别':'男'}

虽然看起来比较整齐,但其实录入的时候很麻烦,所以我们需要一个优雅地方式,函数

def luru(people,xm,nn,xb):people['姓名']=xmpeople['年龄']=nnpeople['性别']=xb
student1=dict()
luru(student1,'hh',19,'男')

这样输入信息只需要一个简单的函数了对吧,但是如果我现在想要输出内容呢?可能需要另一个函数

def shuchu(people):for k,v in people.items():print(k,v)
def luru(people,xm,nn,xb):people['姓名']=xmpeople['年龄']=nnpeople['性别']=xb
student1=dict()
luru(student1,'hh',19,'男')
shuchu(student1)

那么现在是一个学生,但如果有很多个学生,我就需要定义很多个dict再把他们放到一个函数里去赋值,而且如果有很多个函数呢?而且他们都是有关学生的相关操作,这样对同一种类型的对象进行操作和初始化的过程,就可以被放进一个大大的类(class)里面。

类的操作

class student:#student是类的名字,下面都要用这个来命名def __init__(self,name,age,gender):#每个类在被定义的时候都会运行一遍这个初始化函数就是__init_()self.name=nameself.age=ageself.gender=gender# 这是初始化函数,一个对象肯定有他的最初信息的,如果真没有,可以pass掉# 这里的self是表示属于这一类的变量,其实就是student.name,表示这个变量是属于这个类的# 不加self.的变量不被认为是这个类的变量def print_xx(self):#这里有没有参数都要加上self表示这是属于这一类的函数print(self.name)print(self.age)print(self.gender)student1=student('hh',19,'男')
student1.print_xx()

        这里对这个self进行一个解释,作用就是说明这个变量或者这个函数是这个类所拥有的,其实你可以把这个self看作是一个躯壳,然后在student1被定义这个类以后,这个躯壳就被装进student1的灵魂了,所以之前就是self.name表示是self的name,然后现在就是student1.name表示是第一个学生的名字。然后你就可以在之后的函数中对其进行使用了,但是注意类里面的函数都要加上self的参数,表示这是这个类的函数,否则会报错。

然后你就可以快乐的使用类对一个变量进行定义,类里的函数也可以使用

(因为调用类的时候要用xx.yy,我有时候觉得这就像一个带了函数的python里类似c++的结构体的东西,区别就是带了函数)

class student:def __init__(self,name,age,gender):self.age=ageself.gender=genderdef print_xx(self):print(self.name)print(self.age)print(self.gender)student1=student('hh',19,'男')
student1.print_xx()
student2=student('nn',20,'男')
student2.print_xx()
student3=student('ww',20,'男')
student3.print_xx()

看,这样是不是就很方便录入信息和进行操作了,优雅~

类的拓展

类的继承

在这里,我们进一步对类进行应用,那么学生之间亦有不同,就像英专生和计算机学生,他们虽然都需要录入相同的个人基本信息,但是英专生需要额外录入他的英语四六级成绩,而计算机学生需要录入他的csp得分,这其实就有所不同了,那么怎么办呢?,我们可以先把他们都认为是学生,然后在学生的基础上再细分英专生和计科生。

class student:def __init__(self,name,age,gender):self.name=nameself.age=ageself.gender=genderdef print_xx(self):print(self.name)print(self.age)print(self.gender)class Endlish_student(student):def __init__(self,name,age,gender,cet4,cet6):super().__init__(name,age,gender)self.cet4=cet4self.cet6=cet6def print_x(self):super().print_xx()print(self.cet4)print(self.cet6)class Computer_student(student):def __init__(self,name,age,gender,csp):super().__init__(name,age,gender)self.csp=cspdef print_x(self):super().print_xx()print(self.csp)student4=Endlish_student('gg',20,'男',600,550)
student4.print_x()#他可以输出自己的函数
student4.print_xx()#他依然可以继承父类的函数
student5=Computer_student('gg',20,'男',400)
student5.print_x()#他可以输出自己的函数
student5.print_xx()#他依然可以继承父类的函数

我们可以在定义类的时候在后面加小括号并且输入父类,这样他就可以继承父类的所有变量,函数了,但是需要注意的是,继承函数是指在类以外可以,如果在类里面要使用父类的函数的话,那么需要使用super().这个前缀表示使用是父类的函数。

但是定义好了之后,在使用时,就可以直接使用父类的函数即可(一般不使用初始化函数)。

ps:正因为使用时可以直接使用父类和子类的函数,但是如果子类和父类有两个相同的函数,那么默认先使用子类的函数。

这就叫做类的继承。

类的多态

对于类的复用,即相同的函数发挥不一样的作用,上面ps中其实就是一种复用,会先执行子类的函数,其实也就是,哪种类型执行哪种函数,即使名字相同

def printzhaunye(anystudent):anystudent.print_x()
printzhaunye(student4)
printzhaunye(student5)

像这种,就可以将每个类的输出函数名字定义成相同的,那么输入是那一类,就会调用哪一类的输出函数,非常的方便,就可以进行一个输出类型的兼顾。

一些细节

对于类的继承来说,如果不想让子类继承父类的函数或者变量,那么可以在前面加上两个下划线__

那么子类中就不会有相关的函数或者变量了,你也找不到他。

并且如果子类想要用父类的变量可以直接当自己的变量用self.name就可以使用,但是如果要调用父类的函数的话就要用super().__init__(, , , , )这种类型才可以

后记

这就是有关类的一些相关知识,我是蒟蒻,有什么做的不好的希望多多指正,下面是两个我学习类用到的资源:

Class 类 | 莫烦Python

【4个项目学会Python 封装和多态】https://www.bilibili.com/video/BV1Kx421C7C1?vd_source=928e7968871dbf10f26b1952d35eabfa

希望可以帮到大家

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/67163.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

JavaSE学习心得(多线程与网络编程篇)

多线程-网络编程 前言 多线程&JUC 多线程三种实现方式 第一种实现方式 第二种实现方式 第三种实现方式 常见成员方法 买票引发的安全问题 同步代码块 同步方法 Lock锁 生产者和消费者 常见方法 等待唤醒机制 练习 抢红包 抽奖 多线程统计并求最…

Pytorch基础教程:从零实现手写数字分类

文章目录 1.Pytorch简介2.理解tensor2.1 一维矩阵2.2 二维矩阵2.3 三维矩阵 3.创建tensor3.1 你可以直接从一个Python列表或NumPy数组创建一个tensor:3.2 创建特定形状的tensor3.3 创建三维tensor3.4 使用随机数填充tensor3.5 指定tensor的数据类型 4.tensor基本运算…

candb++ windows11运行报错,找不到mfc140.dll

解决问题记录 mfc140.dll下载 注意:放置位置别搞错了

​公专网一体5G工业路由器,智慧电网全链路加密监控管理

随着可再生能源的集成 电网调度策略复杂性增加 需更精细的并网管理以平衡供需 传统电力网络的通信基础落后 难以适应电力设施的广泛分布 和日益增长的管理维护需求 计讯物联5G公专网一体路由器 通过融合公网和专网的优势 有效解决了现代电网对于 高效、灵活和安全通信的需求 ↓…

【Linux】--- 进程的等待与替换

进程的等待与替换 一、进程等待1、进程等待的必要性2、获取子进程status3、进程等待的方法(1)wait()函数(2)waitpid函数 4、多进程创建以及等待的代码模型5、非阻塞接口 轮询 二、进程替换1、替换原理2、替…

intel x99主板设置上电服务器自动启动

作者:吴业亮 博客:wuyeliang.blog.csdn.net 1、选择IntelRCStetup–>PCH state after G3 -->ON PCH state after G3:是指系统完全关闭电源的状态,此时主板上只有RTC(实时时钟)电源。这个选项决定了系…

机器学习-归一化,标准化

标准化(Standardization)是将数据按比例缩放,使其具有特定的统计特征,通常是将数据的均值调整为0,标准差调整为1。标准化是一种常见的数据预处理技术,特别是在进行机器学习时,通常会使用标准化来…

zerotier搭建虚拟局域网,自建planet

基于该开源项目 自建planet节点,更快速,更安全 本教程依据docker-zerotier-planet 项目文档书写,并以linux(centos 7)和windows作为示例,需要其他系统配置方法,可移步项目文档 一. 前置资源 具有外网ip的服务器 后面…

Spring Boot + MyBatis-Flex 配置 ProxySQL 的完整指南

✅ Spring Boot MyBatis-Flex 配置 ProxySQL 的完整指南 下面是一个详细的教程,指导您如何在 Spring Boot 项目中使用 MyBatis-Flex 配置 ProxySQL 进行 读写分离 和 主从同步 的数据库访问。 🎯 目标 在 Spring Boot 中连接 ProxySQL。使用 MyBatis-…

如何解决Webview和H5缓存问题,确保每次加载最新版本的资源

WebView 用于加载 H5 页面是常见的做法,它能够加载远程的 HTML、CSS、JavaScript 资源,并且让 Web 应用嵌入到原生 App 中。然而,WebView 的缓存机制有时会导致用户看到的是旧版本的页面或资源,尤其是在 H5 发版后,iOS…

屏幕轻触间:触摸交互从 “感知” 到 “智算” 的隐秘路径

从用户点击屏幕到前端感知及数据处理全流程剖析 引言 在移动智能设备与触摸交互技术深度融合的当下,当我们的手指轻触手机屏幕,一系列复杂且精妙的技术流程便瞬间启动。这一过程涵盖硬件层、驱动层、操作系统层、应用层,甚至延伸到后端的数…

微调的种类

微调的种类 flyfish 全参数微调(Full Fine-Tuning): 对预训练模型的所有参数进行调整,以优化其在特定任务上的性能。 指令微调(Instruction Fine-Tuning): 通过提供特定任务的明确指令或示例来…

C# 配置文件:app.config 和 web.config

一、引言 在 C# 的应用开发中,配置文件就像是幕后的大管家,默默管理着应用程序的各种设置。今天,我们就来深入探索一下 C# 中极为重要的两个配置文件:app.config 和 web.config。无论是开发 Windows 应用程序,还是构建…

java 设计模式 工厂模式

什么是工厂模式 工厂模式(Factory Pattern)是一种创建型设计模式,它通过定义一个接口或抽象类来创建对象,但由子类决定具体实例化哪个类。简单来说,工厂模式将对象的实例化过程封装起来,客户端通过工厂方法…

[创业之路-248]:《华为流程变革:责权利梳理与流程体系建设》华为流程的前端拉动后端,与计算机软件的前端应用与后端程序的类比关系

华为的前端拉动后端模式与计算机前端应用与后端程序的类比关系,虽然两者属于不同的领域,但在某些方面存在有趣的相似性。以下是对这两者的类比关系的详细探讨: 一、华为的前端拉动后端模式 定义与特点: 华为的前端拉动后端模式是…

深入Node.js集群:原理、优势与搭建实战,如何应对高并发

文章目录 一、Node.js 集群简介二、Node.js 集群原理剖析2.1 主从模型2.2 负载均衡机制2.3 进程间通信(IPC) 三、Node.js 集群优势详解3.1 性能提升3.2 高可用性3.3 资源利用率优化 四、Node.js 集群搭建实战4.1 准备工作4.2 创建主控制节点4.3 工作节点…

数字普惠金融对新质生产力的影响研究(2015-2023年)

基于2015—2023年中国制造业上市公司数据,探讨了数字普惠金融对制造业企业新质生产力的影响及作用机理。研究发现,数字普惠金融有助于促进制造业企业新质生产力的发展,尤其是在数字普惠金融的使用深度较大的情况下,其对新质生产力…

数据仓库基础常见面试题

1.数据仓库是什么 ‌数据仓库(Data Warehouse)是一个面向主题的、集成的、非易失的、随时间变化的数据集合,用于支持企业的管理决策‌。它不同于传统的操作型数据库,后者主要用于处理日常业务交易和实时查询,而数据仓库…

记一次OpenEuler Linux磁盘分区表损坏的数据恢复

问题复现 原本有一台GIS地图服务器存放大量数据,突然有一天磁盘满了,于是运维人员照常进行磁盘扩容。但由于误操作,导致使用fdisk的时候把分区表损坏了,表现如下: 这里可以看到启动时能看到xvda被分为了xvda1和xvda2…

分布式数据存储基础与HDFS操作实践(副本)

以下为作者本人撰写的报告,步骤略有繁琐,不建议作为参考内容,可以适当浏览,进一步理解。 一、实验目的 1、理解分布式文件系统的基本概念和工作原理。 2、掌握Hadoop分布式文件系统(HDFS)的基本操作。 …