Python是一门面向对象的编程语言,那么今天我们着重讲一下如何处理"对象"
一、文件
之前接触到的一系列数据值,都是在内存中的,也就是不会永久保存。当数据量非常小的时候,当然可以每次都临时定义生成,但如果数据量稍大,这样处理就不合适了。结合我们平时使用电脑的习惯,其实大部分数据都是以“文件”式存在于硬盘里的,比如.avi, .torrent, .exe, .txt等。
1.open函数
利用python的内置函数open()可以执行打开文件的操作,对于一些python的数据科学库像numpy和panda有自己的文件读取函数。下面我们通过一个简单的例子展示一下:
open(“hope.txt”, “r”)
open函数与我们之前介绍的print函数不同,接受了两个参数,参数之间以逗号隔开。
“hope.txt”:目标文件名,字符串类型;
“r”:打开模式,"r"代表“只读”(read)。另有"w"表示“写入”(write),"a"表示“增补”(append)。
但是open函数并不会显示文件的内容,比如看下面的这个例子:
当你运行这段代码将会得到
<_io.TextIOWrapper name=‘taijian.txt’ mode=‘r’ encoding=‘UTF-8’>
答案:
data = f.read()mons = data.split(’
‘)for i in mons:mons_data.append(i.split(’,'))
如果有一个函数,只要指定目标csv文件,就可以直接生成二维数组,岂不美哉?但是Python并没有内置这样的功能,那就需要定义自己的函数。函数定义的关键字是def,也就是"define"的缩写。定义语句格式与for循环有些类似,同样包括语句头和语句体,需要特别注意的仍然是语句头结尾的冒号(:)和语句体的缩进:
我们希望能够有一个函数,读取指定的csv文件,返回经过切分的二维数组,那么这个函数应该是这样的:
函数名:tokenize,想要调用这个自定义函数的时候,直接写tokenize()即可,就像我们使用print(), type()一样。
参数:想要处理的数据文件名,对于Dota2的例子,就是dota2_heroes.csv。
函数体:也就是上一节所写的代码段,为了函数更加通用,我修改了部分变量名称。
返回值:关键字return之后是经过函数得到的结果。
二、类和对象
类(class)描述和规范了某一类事物的特征和行为。比如有一个类,叫“车”。那么这个类就描述了一种物体的特征和行为,特征比如有轮子,行为比方说会移动。车这个类好比一张蓝图,各种各样的车都是根据车的基本特征设计制造出来的。
“类”的概念是抽象的,我们虽然修过了一辆辆车,但不会真的关注“车”作为类的本质等哲♂学命题。具体到某一辆车就是对象(object),对象是类的实例,如果说类是蓝图,对象就是把一张蓝图绘到底。
Python是一门面向对象的编程语言,可以说在Python中所有东西都是对象(你们有对象了吗?),比如int, str, bool这些我们已经见过的数据类型,甚至模块、函数,全都是对象。这个按照蓝图造车的过程,就叫类的实例化。你拥有的车就是类的实例,即对象。所以说,要有对象,首先要定义类。
如何定义一个类呢?
和定义函数一样,定义类也是一个“语句头+语句体”组成的复合语句,用到的关键字是 class。定义一个名为 Creature 的类,其语法结构如图:
类的名称跟在class关键词之后,和冒号(:)之前。类用实例变量(instance variable)来存储数据,以及方法(method)来定义行为。关于超类的概念不必惊慌,下一章就会详细讲解,没有超类的情况下,类名之后的括号也可以省略。
为了使定义的过程看上去尽可能简单,语句体中只有一个 pass,也就是什么也不做的意思。
一般的类还会包含:
方法:用来定义行为
实例变量:存储数据
什么是方法?
方法描述了对象的行为,本质上它是定义在类中的函数。调用对象方法的过程,和我们之前在函数一章中调用函数是相似的,比如对于字符串对象,想要调用.split()方法来进行分割(#号后面的就是输出结果):
在之前的章节习题中,我们已经接触过了类的相关的用法。假设现有类Person,含有了一个方法,叫做 whoami,用于返回对象的名字。那我们调用这个方法的过程是这样的:
其实上面这个程序 Trevor = Person() 这一行,不管你把 kaiser 改成什么,输出的都是我的名字。显然,这个 whoami 方法是有问题的。
如果你把类语句体里的 ‘Trevor’ 改成别的内容,那就会输出别的内容。但我们需要的是输出这个 Person 对象的名字,大家的名字都不相同,怎么做呢?这就需要类 Person 能够存储数据,也就是要有实例变量。
三、实例变量
介绍实例变量之前,先介绍一下初始化器(initializer或constructor)。Python 的类都自带有一些特殊的方法,它就是其中之一。
初始化器的“初始化”,指的是对象的初始化,其实也就是类的实例化。如果我们要在实例化 Person 的时候,给它一个名字,可以加在实例化时的括号里。
初始化器的方法名长这样:init。别怕下划线,这只是为了标明些方法的特殊性。
定义初始化器和平时定义方法是一样的,我们需要把这个人的名字传入到初始化器。那么初始化器应该这样定义:
哦,在这停顿!这里出现的 self.name,就是我们的实例变量。实例变量的用途(第三次提起)是存储数据,那么这里我们是存储了名字。这样实现过初始化器之后,就可以实例化 Person ,并赋予它一个名字了。
Python的所有方法,其第一个参数都是self,这个参数指代的是调用该方法的对象。调用方法时,不需要传入self参数,Python解释器会自动完成这一步。对象的实例变量可以在生成后修改,但是并不推荐这样做,所以实践当中最好隐藏变量对外的接口。在实际的开发中经常会遇到这种情况:我们不希望对象的某些实例变量被访问和修改。为此需要隐藏这些实例变量,即定义私有实例变量。在Python中,以两条下划线()开头的变量,就是私有实例变量。方法同样可以定义为私有,也是以两条下划线()开头。
四、继承与派生
继承(inheritance)使得开发者可以先创建一个较为宽泛的类,再逐步拓展细化成为更具体的类,就好比先定义“动物”,再继承得出“哺乳动物”。
通过继承,我们可以访问所有的数据域(实例变量)和方法,此外还可以加入我们自己的变量和方法。继承提供了一种组织代码的方式,这样就不用每次都从零重写,极大地提高了编码效率,也是一种更好的代码风格。如果类Y继承了类X,那么X叫作“超类”(super class)或“基类”(base class),Y叫作“子类”(subclass)或“派生类”(derived class)。其实就是父子关系:
创建子类的语法:
之前我们定义过的类如Person,类名之后都是没有括号的,因为他们并没有继承其他超类。
与C#, Java这些语言不同,Python允许多重继承,也就是可以认好几个爹:
最后,今天来一波毒鸡汤
小编在此谢谢大家的观看!Python很容易学!
最后,想学习Python的小伙伴们!
关于Python技术储备
学好 Python 不论是就业还是做副业赚钱都不错,但要学会 Python 还是要有一个学习规划。最后大家分享一份全套的 Python 学习资料,给那些想学习 Python 的小伙伴们一点帮助!
一、Python所有方向的学习路线
Python所有方向的技术点做的整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。
二、Python必备开发工具
三、Python视频合集
观看零基础学习视频,看视频学习是最快捷也是最有效果的方式,跟着视频中老师的思路,从基础到深入,还是很容易入门的。(文末领读者福利)
四、实战案例
光学理论是没用的,要学会跟着一起敲,要动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。(文末领读者福利)
五、Python练习题
检查学习结果。
六、面试资料
我们学习Python必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有阿里大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。 (文末领取哦)