史上最全Python面向对象编程的资料合集.doc
《史上最全Python面向对象编程的资料合集.doc》由会员分享,可在线阅读,更多相关《史上最全Python面向对象编程的资料合集.doc(14页珍藏版)》请在三一办公上搜索。
1、史上最全Python面向对象编程的资料合集面向对象编程和函数式编程(面向过程编程)都是程序设计的方法,不过稍有区别。面向过程编程:1.导入各种外部库2.设计各种全局变量3.写一个函数完成某个功能4.写一个函数完成某个功能5.写一个函数完成某个功能6.写一个函数完成某个功能7.写一个函数完成某个功能8.9.写一个main函数作为程序入口在多函数程序中,许多重要的数据被放置在全局数据区,这样它们可以被所有的函数访问。每个函数都可以具有它们自己的局部数据,将某些功能代码封装到函数中,日后便无需重复编写,仅调用函数即可。从代码的组织形式来看就是根据业务逻辑从上到下垒代码 。面向对象编程:1.导入各种外
2、部库2.设计各种全局变量3.决定你要的类4.给每个类提供完整的一组操作5.明确地使用继承来表现不同类之间的共同点6.根据需要,决定是否写一个main函数作为程序入口面向对象编程中,将函数和变量进一步封装成类,类才是程序的基本元素,它将数据和操作紧密地连结在一起,并保护数据不会被外界的函数意外地改变。类和和类的实例(也称对象)是面向对象的核心概念,是和面向过程编程、函数式编程的根本区别。并不是非要用面向对象编程,要看你的程序怎么设计方便,但是就目前来说,基本上都是在使用面向对象编程。类的基本用法面向对象是通过定义class类来定义,这么说面向对象编程就是只使用class类,在class类中有封装
3、,继承的功能,并且还可以构造要传入的参数,方便控制。案例一importsysimporttimereload(sys)sys.setdefaultencoding(utf-8)classstudetn:#定义一个类名为studetndef_init_(self,idx):#定义初始化构造,这里使用init,还有别的属性比如reversed,iter之类的self.idx=idx#初始化变量,方便继承defrunx(self):#定义运行函数,从上面继承变量printself.idx#打印出idx的值,或者做一些别的处理time.sleep(1)a=studetn(a)a.runx()#这是类的
4、调用,一定要记得类的使用方法,首先传入参数,类赋值给一个变量a#然后调用这个类下面定义的函数一些专业术语概念,既然有面向对象编程这个高大上的定义了,自然要搭配一些高大上的概念。类(Class): 用来描述具有相同属性和方法的对象的集合。它定义了该集合中每个对象所共有的属性和方法。其中的对象被称作类的实例。实例:也称对象。通过类定义的初始化方法,赋予具体的值,成为一个”有血有肉的实体”。实例化:创建类的实例的过程或操作。实例变量:定义在实例中的变量,只作用于当前实例。类变量:类变量是所有实例公有的变量。类变量定义在类中,但在方法体之外。数据成员:类变量、实例变量、方法、类方法、静态方法和属性等的
5、统称。方法:类中定义的函数。静态方法:不需要实例化就可以由类执行的方法类方法:类方法是将类本身作为对象进行操作的方法。方法重写:如果从父类继承的方法不能满足子类的需求,可以对父类的方法进行改写,这个过程也称override。封装:将内部实现包裹起来,对外透明,提供api接口进行调用的机制继承:即一个派生类(derived class)继承父类(base class)的变量和方法。多态:根据对象类型的不同以不同的方式进行处理。类与实例#-*-coding:utf-8-*-#Time:2018/5/3000317:02#Author:Langzi#Blog:langzi.fun#File:面向对象
6、2.py#Software:PyCharmimportsysimporttimeimportrequestsreload(sys)sys.setdefaultencoding(utf-8)classcc:ccc=ccc#cc就是类名如果想要继承别的类就classcc(threading)意思就是从threading继承def_init_(self,a,b,c):self.a=aself.b=bself.c=c#定义构造的过程就是实例化defrunx(self):printself.a*10printself.b*5printself.c*2defruny(self):printrequests
7、.get(http:/langzi.fun).headerse=cc(AAA,CCC,EEE)e.runx()e.runy()#这两个就是调用类里面的方法printe.c#实例变量指的是实例本身拥有的变量。每个实例的变量在内存中都不一样。printe.ccc#类变量,在类里面找到定义的变量。调用类的三种方法实例方法#-*-coding:utf-8-*-#Time:2018/5/3000317:16#Author:Langzi#Blog:langzi.fun#File:面向对象3.py#Software:PyCharmimportsysimporttimeimportrequestsreload
8、(sys)sys.setdefaultencoding(utf-8)classdd:def_init_(self,url):self.url=urldefrunx(self):printrequests.get(self.url).status_codea=dd(http:/langzi.fun)a.runx()#这种调用方法就是实例方法静态方法静态方法由类调用,无默认参数。将实例方法参数中的self去掉,然后在方法定义上方加上staticmethod,就成为静态方法。它属于类,和实例无关。建议只使用类名.静态方法的调用方式。(虽然也可以使用实例名.静态方法的方式调用)#-*-coding:u
9、tf-8-*-#Time:2018/5/3000317:21#Author:Langzi#Blog:langzi.fun#File:面向对象4.py#Software:PyCharmimportsysimportrequestsreload(sys)sys.setdefaultencoding(utf-8)classff:staticmethoddefrunx():printrequests.get(http:/langzi.fun).status_codeff.runx()#这里就直接调用了类的变量,只在类中运行而不在实例中运行的方法经常有一些跟类有关系的功能但在运行时又不需要实例和类参与的
10、情况下需要用到静态方法. 比如更改环境变量或者修改其他类的属性等能用到静态方法. 这种情况可以直接用函数解决, 但这样同样会扩散类内部的代码,造成维护困难。类方法类方法由类调用,采用classmethod装饰,至少传入一个cls(代指类本身,类似self)参数。执行类方法时,自动将调用该方法的类赋值给cls。建议只使用类名.类方法的调用方式。(虽然也可以使用实例名.类方法的方式调用)实际案例如果要构造一个类,接受一个网站和这个网站的状态码,然后打印出来。就像这样:importsysimportrequestsreload(sys)sys.setdefaultencoding(utf-8)cla
11、ssgg:def_init_(self,url,stat):self.url=urlself.stat=statdefouter(self):printself.urlprintself.stata=gg(langzi,200)a.outer()这样就是使用实例方法,虽然可以实现,但是有的时候传入的参数并不是(langzi,200)这样的格式,而是(langzi-200)这样的,那该怎么做?首先要把这个拆分,但是要使用实例方法实现起来很麻烦,这个时候就可以使用类方法。#-*-coding:utf-8-*-#Time:2018/5/3000317:27#Author:Langzi#Blog:la
12、ngzi.fun#File:面向对象5.py#Software:PyCharmimportsysimportrequestsreload(sys)sys.setdefaultencoding(utf-8)classgg:url=0stat=0#因为使用classmethod后会传入新的变量,所以一开始是需要自己先定义类变量def_init_(self,url=0,stat=0):#这里按照正常的定义构造函数self.url=urlself.stat=statclassmethod#装饰器,立马执行下面的函数defsplit(cls,info):#这个函数接受两个参数,默认的cls就是这个类的i
13、nit函数,info就是外面传入进来的url,stat=map(str,info.split(-)#这里转换成了格式化的结构data=cls(url,stat)#然后执行这个类第一个方法,这个类构造函数需要传入两个参数,于是就传入了两个参数returndata#这里就直接返回了函数结果defouter(self):printself.urlprintself.statr=gg.split(langzi-200)r.outer()#这里是调用类方法,与调用实例方法一样类的特性封装封装是指将数据与具体操作的实现代码放在某个对象内部,外部无法访问。必须要先调用类的方法才能启动。案例classcc:c
14、cc=ccc#cc就是类名如果想要继承别的类就classcc(threading)意思就是从threading继承def_init_(self,a,b,c):self.a=aself.b=bself.c=cprinte.ccc#类变量,在类里面找到定义的变量。printccc#这里会报错,这就是封装。类中的函数同理。继承当我们定义一个class的时候,可以从某个现有的class继承,新的class称为子类(Subclass),而被继承的class称为基类、父类或超类(Base class、Super class)。比如,我们已经编写了一个名为Animal的class,有一个run()方法可以直
15、接打印:classAnimal(object):defrun(self):printAnimalisrunning.当我们需要编写Dog和Cat类时,就可以直接从Animal类继承:classDog(Animal):passclassCat(Animal):pass继承有什么好处?最大的好处是子类获得了父类的全部功能。由于Animial实现了run()方法,因此,Dog和Cat作为它的子类,什么事也没干,就自动拥有了run()方法:dog=Dog()dog.run()cat=Cat()cat.run()当子类和父类都存在相同的run()方法时,我们说,子类的run()覆盖了父类的run(),在
16、代码运行的时候,总是会调用子类的run()。这样,我们就获得了继承的另一个好处:多态。多态要理解多态的好处,我们还需要再编写一个函数,这个函数接受一个Animal类型的变量:defrun_twice(animal):animal.run()animal.run()当我们传入Animal的实例时,run_twice()就打印出:run_twice(Animal()运行结果:Animalisrunning.Animalisrunning.当我们传入Dog的实例时,run_twice()就打印出:run_twice(Dog()运行结果:Dogisrunning.Dogisrunning.当我们传入C
17、at的实例时,run_twice()就打印出:run_twice(Cat()运行结果:Catisrunning.Catisrunning.看上去没啥意思,但是仔细想想,现在,如果我们再定义一个Tortoise类型,也从Animal派生:classTortoise(Animal):defrun(self):printTortoiseisrunningslowly.当我们调用run_twice()时,传入Tortoise的实例:run_twice(Tortoise()运行结果:Tortoiseisrunningslowly.Tortoiseisrunningslowly.你会发现,新增一个Anim
18、al的子类,不必对run_twice()做任何修改,实际上,任何依赖Animal作为参数的函数或者方法都可以不加修改地正常运行,原因就在于多态。多态的好处就是,当我们需要传入Dog、Cat、Tortoise时,我们只需要接收Animal类型就可以了,因为Dog、Cat、Tortoise都是Animal类型,然后,按照Animal类型进行操作即可。由于Animal类型有run()方法,因此,传入的任意类型,只要是Animal类或者子类,就会自动调用实际类型的run()方法,这就是多态的意思:对于一个变量,我们只需要知道它是Animal类型,无需确切地知道它的子类型,就可以放心地调用run()方法
19、,而具体调用的run()方法是作用在Animal、Dog、Cat还是Tortoise对象上,由运行时该对象的确切类型决定,这就是多态真正的威力:调用方只管调用,不管细节,而当我们新增一种Animal的子类时,只要确保run()方法编写正确,不用管原来的代码是如何调用的。这就是著名的“开闭”原则:对扩展开放:允许新增Animal子类;对修改封闭:不需要修改依赖Animal类型的run_twice()等函数。总结:继承可以把父类的所有功能都直接拿过来,这样就不必重零做起,子类只需要新增自己特有的方法,也可以把父类不适合的方法覆盖重写;有了继承,才能有多态。在调用类实例方法的时候,尽量把变量视作父类
20、类型,这样,所有子类类型都可以正常被接收;旧的方式定义Python类允许不从object类继承,但这种编程方式已经严重不推荐使用。任何时候,如果没有合适的类可以继承,就继承自object类。魔法方法在上面有提到除了init之外还有iter,reverse的方法,这里就详细说下除了init初始化还有哪些别的方法。_init_:构造函数,在生成对象时调用_del_:析构函数,释放对象时使用_repr_:打印,转换_setitem_:按照索引赋值_getitem_:按照索引获取值_len_:获得长度_cmp_:比较运算_call_:调用_add_:加运算_sub_:减运算_mul_:乘运算_div_
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 史上最全 Python 面向 对象 编程 资料
链接地址:https://www.31ppt.com/p-4944547.html