如何最简单、通俗地理解python的类?

很多初学的小伙伴们,在学到“类”的时候,就开始烦迷糊了。“类”到底是个什么东西,是用来干嘛的?然后就疯狂百度搜索,搜出了很多。一看回答,很多都是在扯什么面向对象,还讲了一堆稀奇古怪的概念,看了反而更迷糊了。。

所以,我这篇文章,就是要带大家,用最简单、通俗、暴力的方式理解什么是类,类能干什么,怎么使用

首先,我们要明白,既然python的作者设计了“类”这个东西,那肯定是在编程的时候有这种需求的。那我们什么时候需要用到类呢?当然,可以用到类的地方有很多很多。但如果大家还没有太多的代码经验,我就直接告诉你们答案了:如果多个函数需要反复使用同一组数据,使用类来处理,会很方便

举个大家在中学都接触过的例子:解三角形

我需要做一个模块,实现以下功能:输入三角形的三条边长a,b,c,然后计算并返回该三角形三个角的角度,以及该三角形的面积、周长。

在这里插入图片描述

你会说,这很简单啊,我们一般就这么做就行了,假如输入三角形的边长为6,7,8:

def ...:    # 参照公式把五个函数定义出来,就不详细写了
    ...
def ...:
    ...

# 然后调用定义好的函数,传入边长数据
angleA(6,7,8)  # 计算角A
->0.8127555613686607  # 注意返回值为弧度

angleB(6,7,8)  # 计算角B
->1.0107210205683146

angleC(6,7,8)  # 计算角C
->1.318116071652818

square(6,7,8)  # 计算面积
->20.33316256758894

circle(6,7,7)  # 计算周长,额,好像有个数字写错了
->20  # 计算结果当然也就错了

这不就搞定了嘛,把计算需要用到的五个函数依次定义出来,然后调就好了。但大家仔细观察一下,这样写有什么不太好的地方?相信大家都发现了,这是同一个三角形,每次计算角度、面积、周长的时候,都要把三条边的长度传进去,一方面这很麻烦,另一方面,万一有一个不小心写错了,那么那条结果当然也就错了啊。

我们根据三角形全等的条件可以知道,三角形的三条边确定了,那么它的三个角、面积、周长,也就都确定了。所以对于同一个三角形,最好只需要传一次数据就可以了。

这不也简单嘛,把它们都写在一个函数里不就得了:

def calculate(a,b,c):
    angleA = ...
    angleB = ...
    angleC = ...
    square = ...
    circle = ...
    return {'角A':angleA, '角B':angleB, '角C':angleC, '面积':square, '周长':circle}

result=calculate(6,7,8)

result['角A']
->0.8127555613686607

result['面积']
->20.33316256758894

好了,这不又搞定了,看起来没什么问题了吧。看起来当然没有问题了,但大家再仔细想一想,假如我只需要计算“角A”和“面积”,用上面的方法,也只返回了这两个结果,但实际上,那个函数在执行的时候,实际上把五个值都求了一遍。数量少还好,但数量多起来,效率肯定就要大受影响了。

这怎么办呢?聪明的你可能又想到了,在函数里加入第四个参数d,用来标记需要计算哪个,然后函数中插入if语句判断……

得,代码我也不想写了,原来很清晰的逻辑,非得糟蹋成这样。。

这又要使用简便,又要效率高,还要逻辑清晰,这可怎么办呢?我们了想又想,认为函数还是要分开来写的。但我们脑洞一下,最好有一个“大的东西”叫“三角形生成器”,把这些函数包括进来。使用的时候参数直接传给三角形生成器,然后三角形生成器会根据传入的边长生成一个个具体的三角形,生成的三角形除了具有输入进来的边长数据外,还可以自己计算自己的三个角、面积、周长。也就是,我们希望能够实现以下的效果:

# 定义一个“大的东西”,名字就叫triangle
...
...
# 一番神奇的操作,然后

tr1=triangle(6,7,8)  # 把三条边长传给这个大的东西,然后就生成一个三角形赋给tr1

在这行代码里,我们把边长数值传给了“三角形生成器”triangle(),生成了一个三角形,然后赋值给变量tr1。此时的tr1,就代表着边长为6,7,8的具体三角形

然后,我们可以很方便地查看这个三角形三边的边长(也就是刚才传进来的数据):

tr1.a
->6

tr1.b
->7

tr1.c
->8

计算并查看三个角的角度:

tr1.angleA()
->0.8127555613686607

tr1.angleB()
->1.0107210205683146

tr1.angleC()
->1.318116071652818

计算并查看它的面积与周长:

tr1.square()
->20.33316256758894

tr1.circle()
->21

又来了一个边长为8,9,10的三角形:

tr2=triangle(8,9,10)  # 生成另外一个三角形

计算这两个三角形的面积差:

tr2.square()-tr1.square()  # tr2是新生成的三角形,原来的tr1还在呢没删掉
->13.863876777945055

这种想法很大胆是不是?可应该怎么实现呢?这就要用到类了。

可大家在反思一下,这种想法真的很smart吗?在python中,万物皆对象,我们操作字符串、列表、字典、文件IO等内置对象的时候,用的方法,看起来不是一模一样吗。。只不过那个“三角形”是我们自创的而已。讲到这里,你也许已经明白了,类,其实就是提供了自定义对象的能力

好了,不多讲了,我们把上面那个“一番神奇的操作”展开看看吧。

import math  # 计算反三角函数要用到
 
class triangle:  # 定义类:三角形生成器
    def __init__(self,a,b,c):  # 成员函数,声明需要与外部交互的参数(类的属性)
        self.a=a  # 先看着
        self.b=b  # 这几个东西是干嘛的后面会讲
        self.c=c

    def angleA(self):  # 计算函数(类的方法)
        agA=math.acos((self.b**2+self.c**2-self.a**2)/(2*self.b*self.c))
        return agA

    def angleB(self):  # 公式看不懂的回去翻课本去
        agB=math.acos((self.c**2+self.a**2-self.b**2)/(2*self.a*self.c))
        return agB

    def angleC(self):
        agC=math.acos((self.a**2+self.b**2-self.c**2)/(2*self.a*self.b))
        return agC

    def square(self):
        p=(self.a+self.b+self.c)/2
        s=math.sqrt(p*(p-self.a)*(p-self.b)*(p-self.c))
        return s

    def circle(self):
        cz=self.a+self.b+self.c
        return cz

其实也简单,就是先声明包含的参数,然后再写包含的函数就行了。具体的写法规则很多文档都有介绍,我就不多讲了。

用的时候也简单,既然类是自定级对象的规则,那我们就先传入数据,根据规则生成具体的对象(称之为实例化):

tr1=triangle(6,7,8)

像这个,就是根据三角形的生成规则,传入的三条边长,生成的具体三角形,然后那些边长啊、角度啊、面积啊才会有意义。

print(tr1.a)
print(tr1.b)
print(tr1.c)
print(tr1.angleA())
print(tr1.angleB())
print(tr1.angleC())
print(tr1.square())
print(tr1.circle())

->
6
7
8
0.8127555613686607
1.0107210205683146
1.318116071652818
20.33316256758894
21

总结一下,所有的对象,不管是python内置的,还是import第三方包里面的,还是我们自己用类定义然后实例化的,观察总结一下,可以发现,它们都是由两部分组成,一部分是像a、b、c这样的数据,它们决定这个对象是什么,另一部分是像angleA()、angleB()、angleC()这样的函数,他们用来表示用这些数据做什么。在面向对象的编程中,一个对象的数据,称之为对象的属性,一个对象拥有的函数,称之为对象的方法。大家可能经常听说这两个名词,哪怕是其他的编程语言,面向对象作为一种思想,都是相通的。

然后大家可能还有几个问题:

第一个函数def __init()__是干什么的?

顾名思义,init是初始化的意思,init函数,也就是初始化函数,意思就是,当实例化类的时候,自动运行的函数,如果我们实例化的时候给类传了参数,参数也是呈交给这个函数来处理的。所以,你可以在init函数里写上任何你希望实例化的时候就自动执行的函数,比如像print(‘实例化已完成’)什么的都是可以的。

但大部分时候,我们希望实例化的时候干些啥?当然是把数据传给类的属性啊,所以绝大部分情况下,init函数都充当了构造函数的作用,我们可以在这里面写明把传来的数据赋予谁,或经过怎样的预处理后再赋予谁

就拿那个三角形来说,我们希望在生成三角形(实例化)的时候,就给三角形生成器(类)传入三条边长,而不是实例化完了之后,再tr1.a=6,tr1.b=7这样的一个个赋值。所以我们直接就在init函数里写明了参数的传递规则。

另外再说一句,在传入参数实例化后,除了可以查看,也是可以再次修改的:

tr1.a
->6

tr1.a=7
tr1.a
->7

那个self是什么东西,为什么要写self.a?

我们在使用对象的属性的时候,写法是“对象名.属性名”,就像上面的tr1.a。在定义类的时候,为了保持一致,也要采用这种写法。但由于类定义的时候,还没有实例化,并不清楚对象名是什么,所以可以随便写一个(但要前后一致),一般都写self。

看完这篇文章,知道类是什么了吧,然后再去搜索那些你想要的资料,就能看明白了。

关于Python技术储备

学好 Python 不论是就业还是做副业赚钱都不错,但要学会 Python 还是要有一个学习规划。最后大家分享一份全套的 Python 学习资料,给那些想学习 Python 的小伙伴们一点帮助!

对于0基础小白入门:

如果你是零基础小白,想快速入门Python是可以考虑的。

一方面是学习时间相对较短,学习内容更全面更集中。
二方面是可以找到适合自己的学习方案

包括:Python激活码+安装包、Python web开发,Python爬虫,Python数据分析,人工智能、机器学习等习教程。带你从零基础系统性的学好Python!

零基础Python学习资源介绍

👉Python学习路线汇总👈

Python所有方向的技术点做的整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。(全套教程文末领取哈)

👉Python必备开发工具👈

温馨提示:篇幅有限,已打包文件夹,获取方式在:文末

👉Python学习视频600合集👈

观看零基础学习视频,看视频学习是最快捷也是最有效果的方式,跟着视频中老师的思路,从基础到深入,还是很容易入门的。

👉100道Python练习题👈

检查学习结果。

👉面试刷题👈

在这里插入图片描述

在这里插入图片描述

这份完整版的Python全套学习资料已经上传CSDN,朋友们如果需要可以微信扫描下方CSDN官方认证二维码免费领取【保证100%免费

  • 2
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Python是一种易学易用的编程语言,因此对于教授Python的人来说,合适的入门电子书是非常重要的。Python入门电子书应该能够提供简单而详细的介绍,以帮助初学者理解Python编程语言的基础知识和基本概念。 这样的电子书应该包括一个三个主要部分:首先,它应该提供完整的Python编程环境的介绍,以确保初学者了解Python的发展历史,以及Python如何与其他编程语言相比。其次,它应该介绍Python编程语言的基础知识,如变量、字符串、列表、字典和函数等。最后,该书应该为初学者提供一些基础的编程技能练习,以帮助他们更好地理解Python编程语言的思维模式和获得更多实践经验。 除此之外,入门电子书还应该包括许多丰富的范例,以帮助初学者了解实际编程中的应用。同时,它也应该提供许多可选的扩展阅读,以便让初学者了解各种Python库和框架,以及如何将Python应用于不同的行业和领域。 总之,Python入门电子书应该是一个大量资料的综合文集,能够深入浅出地展示Python编程语言的各个方面,帮助初学者建立代码编程的基础知识,为他们的学习之路揭开序幕。 ### 回答2: Python是一种易学易用的编程语言,非常适合初学者入门。针对Python入门者,市面上有很多优秀的电子书。想要选择一本好的Python入门电子书,可以考虑以下几个因素。 首先,应该选择易懂易学的电子书,比如讲解Python基本语法、流程控制和一些常用模块的使用。这些书籍通常既适合初学者又适合有编程经验的人快速了解和掌握Python编程。 其次,建议选择通俗易懂的书籍,语言要用简洁、明快的词汇来表达内容。这样读者能够快速了解Python编程的基本概念和实践操作步骤,更加高效地掌握知识。 第三,应该注意电子书的整体结构,有没有配图、例题、实践操作和编程练习。这些都是辅助学习的好方法。配有丰富的实际编程案例、让读者进行实际操作编程等练习,能够巩固所学知识。 最后,建议读者可以结合个人学习情况和兴趣爱好来选择电子书,毕竟只有兴趣才能让学习变得更容易持久和愉悦。因此,读者可以从以下方面反思自己: 1.我对编程有兴趣吗? 2.我学习其他编程语言的经验是什么? 3.我喜欢在线阅读还是下载后阅读? 4.我学习Python的目的是什么? 结合上述因素,我们可以选择一本适合自己的Python入门电子书,开始学习这门伟大的编程语言! ### 回答3: Python是一种广泛使用的编程语言,被广泛应用于数据科学、Web开发人工智能、自动化等领域。对于想要入门学习Python编程的初学者而言,选择一本入门电子书是非常必要的。 在选择Python入门电子书时,可以基于以下几个方面考虑: 1. 作者背景:选择一位有丰富Python编程经验的作者编写的入门电子书可以确保书中的内容适合初学者的学习。 2. 教学方式:有些电子书采用问答式的教学方式,有些则采用图文并茂、实例丰富的方式进行内容讲解。选择适合自己的教学方式可以使学习效果更好。 3. 合适的难度:有一些Python入门电子书难度过高,导致初学者看不懂。相反,难度过低的入门电子书则不能满足初学者学习深度。因此,选择一本合适难度的电子书十分重要。 4. 互动性:有些Python入门电子书提供在线讨论区和网络论坛,可以与其他初学者交流和分享自己的学习经验。这种互动方式对学习帮助大。 综上所述,选择一本适合自己的Python入门电子书可以使初学者可以在较短时间内掌握Python编程的基本知识,进而为深入学习和实践Python打下坚实的基础。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值