Maison > développement back-end > Tutoriel Python > Caractéristiques de la programmation orientée objet d'apprentissage Python (2)

Caractéristiques de la programmation orientée objet d'apprentissage Python (2)

巴扎黑
Libérer: 2017-04-01 13:34:53
original
1420 Les gens l'ont consulté

Le terme objet dans la programmation orientée objet peut essentiellement être considéré comme un ensemble de données (propriétés) et une série de méthodes qui peuvent accéder et exploiter ces données. Au sens traditionnel, « programme = structure de données + algorithme » est encapsulé, « dissimulé » et simplifié en « programme = objet + message ». Les objets sont des instances de classes et l'abstraction des classes doit être encapsulée. L'encapsulation permet à l'appelant d'utiliser l'objet directement sans se soucier de la façon dont l'objet est construit.

Expliquez d'abord les spécifications de programmation Python :

#!/usr/bin/env python
#coding=utf-8
#编程规范,示例如下:
 
class ClassName(object):
       '''testdoc         #这里面是一些说明文档,该类的说明信息是可以被help看到的
              example:
       '''
       #注释的写法,可以在后面,也可以在上一行,单行注释以#号开头
       a= 100          #this is a number for a
       #thisis a number for b
       b= 200
       c= ['a','b']   #or 分行写
       d= {                                   #列表、字典等可以分行写,这样更加直观
                     'key1':'v1',
                     'key2':'v2',
                     'key3':'v3'
       }
 
       def__init__(self,num,m):                   #初始化方法。如果不写,则是从基类继承
              self.age= num
              self.__money= m
 
       deftest(self):
              return100
 
       def__eq__(self,other):                 #魔术方法
              returnself.age == other.age
 
       def__del__(self):   #析构函数,在整个类调用执行完后会执行
              print'world'
 
d = Hello(2,200)
d2 = Hello(3,100)
 
print d == d2         #会自动调用__eq__方法,返回比较结果
 
print d
print d2
Copier après la connexion



L'écriture des spécifications commence généralement à partir d'un texte explicatif, d'une méthode d'initialisation, d'une seule ligne ou plusieurs lignes Commentaires, etc.

1. Méthode de construction :

L'exemple suivant illustre l'ordre d'exécution de la méthode de construction et de la méthode d'initialisation :

#!/usr/bin/env python
 
class Of(object):
 
       def __new__(cls,*args,**kwargs):               #构造方法
                print 'new'
                return super(Of,cls).__new__(cls,*args,**kwargs)
                #returnobject.__new__(cls,*args,**kwargs)
 
       def __init__(self):                #初始化方法
                print "init"
 
       def test(self):
                print 'hello'
 
f = Of()
Copier après la connexion

Les résultats de l'exécution sont les suivants :

new
init
Copier après la connexion

illustre que lorsque la classe est instanciée, elle exécutera d'abord la méthode constructeur, puis exécutera la méthode d'initialisation

L'exemple suivant illustre la méthode constructeur et la méthode d'initialisation. La différence :

#!/usr/bin/env python
 
class Resource(object):                 #父类的定义
       def __init__(self):                #初始化方法,为了说明这里直接输出名字
                print 'call me resource init'
 
       def __new__(cls,*args,**kwargs):               #构造方法,这里使用这种传参可以接受任何类型的参数
                print "resource new"
                returnobject.__new__(cls,*args,**kwargs)         #返回值为object基类的构造方法的返回值
 
class DockerResource(Resource):         #子类的定义,继承了Resource类
       def __new__(cls,*args,**kwargs):               #重新构造自己的构造方法
                print "call me dockerresource new"
                returnResource.__new__(cls,*args,**kwargs)            #返回值为Resource父类的构造方法的返回值
 
 
       def __init__(self):                #定义自己的初始化方法
                print 'call docker resourceinit'
 
       def test(self):                #定义test方法
                print 'dosker resource test'
 
r = DockerResource()                  #实例化DockerResource,并将返回值传递给r
print r                          #打印r,查看返回值是什么
print type(r)                  #查看r的类型
r.test()
Copier après la connexion

Le résultat de sortie est le suivant :

call me docker resource new                #首先调用了DockerResource的构造方法
resource new                                      #构造方法返回的是Resource的构造方法,所以会执行Resource父类构造方法的print "resource new"
call docker resource init                      #然后会执行自己的初始化方法
<__main__.DockerResource object at0x7fa1a3edcf90>             #r现在接受的是Resource父类的构造方法的返回值,所以会有object出现
<class &#39;__main__.DockerResource&#39;>                    #类型为自己DockerResource
dosker resource test                                   #调用自己的test方法
Copier après la connexion

Dans le classe, son propre constructeur sera exécuté en premier, sinon il proviendra de la classe parent Inherit, puis exécutera sa propre méthode d'initialisation. Sinon, il héritera toujours de la classe parent. Vous pourrez ensuite appeler votre propre méthode d'instance normalement.


2. Héritage :
L'exemple suivant illustre que la sous-classe hérite de la classe parent

#!/usr/bin/env python
 
class Resource(object):                 #定义一个父类,继承于object基类
 
       def __new__(cls,*args,**kwargs):        #构造方法
                print &#39;class resource __new__&#39;
                obj =super(Resource,cls).__new__(cls,*args,**kwargs)            #利用super函数找到自己的父类,并将它的构造方法传递给obj
                print obj.__class__        #打印obj的类型
                return obj                     #返回值为obj
 
       def __init__(self):                       #初始化方法
                print "call me init forResource"
 
       def test(self):
                print "call me test forResource"
 
       def create(self):
                print "call me create forResource"
 
class subResource(Resource):               #定义子类,继承Resource父类
 
       def __init__(self):                #定义自己的初始化方法
                print &#39;sub resource init&#39;
 
       def test(self):
                print &#39;sub resource test&#39;
 
class Heat(object):                #定义一个Heat类,继承于基类object,是个新式类
 
       def __new__(cls,*args,**kwargs):               #定义自己的构造方法
                print "class __new__%s" % cls
                returnobject.__new__(cls,*args,**kwargs)                #返回值为object基类的构造方法的返回值
 
       def __init__(self):                #定义初始化方法
                print &#39;heat init&#39;
 
 
r = Heat()                     #实例化
print r
h = Resource()              #实例化
print h
f = subResource()          #实例化
print f
Copier après la connexion

Les résultats d'exécution sont les suivants suit :

class __new__ <class &#39;__main__.Heat&#39;>               #实例化Heat类,首先执行自己的构造方法和初始化方法,所以先输出构造方法的print语句
heat init                        #执行了自己的初始化方法
<__main__.Heat object at0x7f43349ac050>                     #r实例化后继承的是object基类,打印返回值
class resource __new__                #实例化Resource类,首先执行自己的构造方法和初始化方法,所以先输出构造方法的print语句
<class &#39;__main__.Resource&#39;>         #打印父类构造方法的返回值的类名
call me init for Resource                     #执行自己的初始化方法
<__main__.Resource object at0x7f43349ac090>               # h实例化后继承的是object基类,打印返回值
 
class resource __new__                #实例化subResource类,首先执行父类的构造方法,所以先输出父类构造方法的print语句
<class &#39;__main__.subResource&#39;>           #父类构造方法里面打印自己的类名
sub resource init                   #执行自己的初始化方法
<__main__.subResource object at0x7f43349ac0d0>                 #f实例化后是执行了父类Resource类的构造方法,返回的依旧是object基类
Copier après la connexion



Trois , Héritage multiple :

#!/usr/bin/env python
 
class A(object):
       def __init__(self):
               pass
       def ma(self):
                print &#39;a.ma&#39;
       def m(self):
                print &#39;it is A&#39;
class B(object):
       def mb(self):
                print &#39;b.mb&#39;
       def m(self):
                print &#39;it is B&#39;
 
class C(A,B):
       pass
 
c = C()
c.ma()
c.mb()
c.m()
Copier après la connexion

Le résultat de l'exécution est le suivant :

a.ma
b.mb
it is A
Copier après la connexion

Grâce au résultat de l'exécution, nous pouvons voir que C hérite de A et B, il peut donc appeler la méthode ma() de A ou la méthode mb() de B mais quand A et B ont la méthode ; même méthode, elle donnera la priorité à la première super classe héritée.

4. Héritage et surcharge :

#!/usr/bin/env python
 
class Phone(object):
 
       def __init__(self,size,color,memory):
                self.size = size
                self.color = color
                self.memory = memory
 
       def call(self):
                s = &#39;I can call&#39;
                return s
       def sms(self):
                s = &#39;Are you gua le mei?&#39;
#!/usr/bin/env python
 
class Phone(object):
 
       def __init__(self,size,color,memory):
                self.size = size
                self.color = color
                self.memory = memory
 
       def call(self):
                s = &#39;I can call&#39;
                return s
       def sms(self):
                s = &#39;Are you gua le mei?&#39;
                return s
 
class Phones(Phone):            #继承了Phone类,重载了自己的初始化方法,又增加了自己的方法,既拥有超类的方法,又有自己特有的方法
 
       def __init__(self,size,color,memory,pix):
                self.pix = pix
               super(Phones,self).__init__(size,color,memory)
 
       def install_app(self,app):
                s = &#39;install %s&#39; % app
                return s
 
class Huwei(Phone):                    #继承了Phone类,又增加了自己的方法,既拥有超类的方法,又有自己特有的方法
 
       def weixin(self,msg):
                if msg.find(&#39;gcd&#39;) == -1:
                        return &#39;sending....&#39;
                else:
                        return &#39;You can\&#39;t sendthe msg&#39;
 
p = Phone(1.2,&#39;black&#39;,&#39;4M&#39;)                  #实例化
 
iphone =Phones(4.7,&#39;white&#39;,&#39;4G&#39;,&#39;1280*766&#39;)        #实例化
 
h = Huwei(4.7,&#39;yellow&#39;,&#39;4G&#39;)                #实例化
 
print iphone.install_app(&#39;weixin&#39;)          #执行特有的install_app方法
 
print h.sms()
print h.call()
print h.weixin(&#39;wansui&#39;)
sms = p.sms()
call = p.call()
print sms,call
Copier après la connexion

Les résultats d'exécution sont les suivants :

install weixin
Are you gua le mei?
I can call
sending....
Are you gua le mei? I can call
Copier après la connexion

Surcharge de la méthode Loading est en fait une méthode de surcharge de la classe parent en utilisant le mot-clé def dans la classe. Si vous surchargez une méthode dans la classe parent mais devez
utiliser la méthode de la classe parent dans la classe, vous pouvez utiliser le nom de la classe parent plus '.' plus le nom de la méthode pour appeler

5 , Méthode magique :

#!/usr/bin/env python
 
class Information(object):
       &#39;&#39;&#39;This is a doc                #说明文档
                example for test,please don&#39;tchange it.
       &#39;&#39;&#39;
 
       def __init__(self,sch,cla,m,n):             #定义初始化方法
                print "welecome to schoolsystem."
                self.school = sch                   #实例变量
                self.classroom = cla                     #实例变量
                self.num = 100                     #实例变量
                self.__money = m                #私有变量
                self.num = n                        #实例变量
 
       def school_name(self):                 #返回实例变量,即将实例变量传递出去
                return self.school
 
       def class_name(self):                   #返回实例变量,即将实例变量传递出去
                return self.classroom
 
       def class_money(self):                 #返回私有变量,即将私有变量传递出去
                return self.__money
              #魔术方法:以双下划线开头,以双下划线结尾的方法是魔术方法
       def __eq__(self,another):             #当外部出现&#39;==&#39;比较的时候,调用此魔术方法
                return self.__money ==another.__money           #返回两个私有变量的比较结果(布尔值),这里self是&#39;==&#39;左边的参数值,another是右边的参数值
 
       def __gt__(self,another):                     #当外部出现&#39;>&#39;比较的时候,调用此魔术方法
                return self.__money >another.__money             #返回两个私有变量的比较结果(布尔值),这里self是&#39;>&#39;左边的参数值,another是右边的参数值
 
       def __ne__(self,another):             #当外部出现&#39;!=&#39;比较的时候,调用此魔术方法
                return self.__money !=another.__money            #返回两个私有变量的比较结果(布尔值),这里self是&#39;!=&#39;左边的参数值,another是右边的参数值
 
       def __add__(self,another):            #当外部出现&#39;+&#39;运算符的时候,调用此魔术方法
                return self.__money +another.__money      #返回两个私有变量的相加结果,这里self是&#39;!=&#39;左边的参数值,another是右边的参数值
                #returnInformation(&#39;jiaoda&#39;,&#39;dz1302&#39;,self.__money + another.__money)
                #return Information(&#39;jiaoda&#39;,&#39;dz1302&#39;,1024,self.num+ another.num)
 
       def __str__(self):
                return &#39;money = %d&#39; %self.__money
 
       def __hash__(self):               #获取hash值
                return 1314521
 
       def __getattr__(self,name):                  #当调用不存在的方法时,执行此方法进行输出
                print "get attr %s" %name
                return name
 
       def __del__(self):          #析构方法,当不再使用此类时,会自动执行
                print "Goodbye,welecomhere again."
 
f = Information(&#39;youdian&#39;,&#39;tg1312&#39;,9999,6)           #实例化
l = Information(&#39;ligong&#39;,&#39;jk1213&#39;,6666,4)             #实例化
print f == l            #调用魔术方法__eq__()
print f + l                     #调用魔术方法__add__()
print f > l                     #调用魔术方法__gt__()
 
s = f + l                 #
print s
print f.ccc              #名字不存在,调用__getatter__()方法
Copier après la connexion



__str__ est appelée par la fonction d'impression et renvoie généralement quelque chose. Cette chose doit être exprimée sous la forme d'une chaîne. Sinon, utilisez la fonction str() pour convertir. Lorsque vous imprimez une classe, la première chose que print appelle est le __str__

défini dans la classe. Le résultat de l'exécution est le suivant :

welecome to school system.          #首先会在实例化的时候执行初始化方法
welecome to school system.          #第二次实例化调用初始化方法
False                     #打印__eq__()的返回值为False
16665                   #打印__add__()的返回值为两数相加
True                      #打印__gt__()的返回值为True
16665
get attr ccc             #执行__getattr__()方法
ccc
Goodbye,welecom here again.             #执行完会自动执行析构函数
Goodbye,welecom here again.
Copier après la connexion



. 6. Modules :
En python, il est livré avec plus de 200 modules. Maintenant, après l'amélioration continue de chacun, le site officiel a collecté plus de 2 000 modules de bibliothèque, qui peuvent réaliser presque tout ce que vous voulez. . Fonction.

Lorsque nous l'utilisons nous-mêmes, nous pouvons également utiliser notre propre module. N'importe quel .py peut être importé en tant que module séparé

Maintenant, nous définissons d'abord notre propre module : module py.

#!/usr/bin/env python
#coding=utf-8
 
def test():
       print&#39;This is a test&#39;
 
def test2():
       print&#39;test2&#39;
 
class DB(object):
       def__init__(self):
              self.a= 101
       deftest(self):
              returnself.a
Copier après la connexion

Dans le même répertoire, ouvrez python de manière interactive et vous pouvez importer ce module. Le nom est le nom du module de fichier
est écrit dans le fichier pour effectuer l'appel d'importation ; ,,,, , voici le résultat dans le même répertoire (même calque)

#!/usr/bin/env python
 
import module
module.test()
Copier après la connexion

comme suit :

This is a test
Copier après la connexion

Améliorez-le et appelez la classe dans le module :

#!/usr/bin/env python
 
import module
h = module.DB()
print h.test()
Copier après la connexion

Les résultats de sortie sont les suivants :

101
Copier après la connexion

Ensuite, nous essayons d'importer le module dans un répertoire :
Créer un nouveau répertoire chauffez et écrivez-le dedans Plusieurs fichiers de module doivent avoir __init__.py dans le répertoire
pour être importés en tant que modules

Caractéristiques de la programmation orientée objet d'apprentissage Python (2)


Le contenu de docker .py dans le répertoire heat est :

#!/usr/bin/env python
 
def docker():
       return&#39;This is a docker in heat&#39;
 
class Docker(object):
       defcreate_c(self):
              return&#39;1314521aaa&#39;
 
       defstop_c(self):
              return&#39;it is stop&#39;
 
print __name__
 
if __name__ == &#39;__main__&#39;:
       print__name__
       d= Docker()
Copier après la connexion



Le contenu de nova.py dans le répertoire heat est :

#!/usr/bin/env python
 
def nova():
       return&#39;This is a nova&#39;
 
class Nova(object):
       deftest(self):
              return&#39;This is a test in nova&#39;
Copier après la connexion



Maintenant dans le répertoire heat Il n'y a que le fichier __init__, mais il n'y a aucun contenu dans le fichier

Écrivez un fichier de script appelant :

#!/usr/bin/env python
#coding=utf-8
 
import heat.docker               #目录下__init__.py里面没有__all__
printheat.docker.docker()
Copier après la connexion

Le résultat de l'exécution est le suivant :

heat.docker
This is a docker in heat
This is a docker in heat
Copier après la connexion

Maintenant, seuls les modules spécifiques du répertoire peuvent être importés, qui peuvent être importés et appelés comme ci-dessus

Afin de tous importer ; fichiers du module dans le répertoire, vous pouvez saisir __init__.py dans le répertoire Ajoutez le contenu suivant :

__all__ = [&#39;docker&#39;,&#39;nova&#39;]                    #将所有模块名字写入
Copier après la connexion

Modifiez le contenu du fichier exécutable :

#!/usr/bin/env python
#coding=utf-8
 
import heat.docker               #目录下__init__.py里面没有__all__
print heat.docker.docker()
 
from heat import *               #heat目录下__init__里面内容是:__all__ = [&#39;docker&#39;,nova&#39;]
print docker.docker()
print nova.nova()
n = nova.Nova()
print n.test()
Copier après la connexion

Le résultat de l'exécution est le suivant :

heat.docker
This is a docker in heat
This is a docker in heat
This is a nova
This is a test in nova
Copier après la connexion

S'il y a un module dans le répertoire qui doit être importé, vous pouvez continuer à y écrire le fichier __init__.py et écrire le nom du fichier du module dans le répertoire, et ajoutez simplement une couche supplémentaire de répertoires lors de l'appel.

Caractéristiques de la programmation orientée objet d'apprentissage Python (2)

Ce qui suit est un exemple du contenu du fichier mod.py :

#!/usr/bin/env python
#coding=utf-8
 
def hello():
       return&#39;hello everyone&#39;
 
class Hello(object):
       def__init__(self):
              self.a= 103
       deftest(self):
              return&#39;This is a test in Hello&#39;
Copier après la connexion

Exécutez le script suivant pour tester :

#!/usr/bin/env python
#coding=utf-8
 
from heat.common import mod
 
print mod.hello()
h = mod.Hello()
print h.test()
Copier après la connexion

Les résultats de l'exécution sont les suivants :

hello everyone
This is a test in Hello
Copier après la connexion



Si vous avez besoin de tous les fichiers du module à l'intérieur, continuez simplement à écrire dans le Fichier __init__.py .

Il est à noter que lorsqu'un fichier est importé en tant que module, un fichier .pyc sera généré. Si le module est modifié, le fichier .pyc doit être actualisé, sinon les anciennes informations seront toujours lues. .

Afin d'éviter que le fichier soit utilisé comme module, nous devons ajouter

au fichier
if __name__ == &#39;__main__&#39;:
       pass               #这里是要执行的语句
Copier après la connexion


这样就可以防止当文件是被用作模块使用时,不会被执行if下面的语句,如果是当做程序来执行时,则会执行下面的语句,一般用作测试。

本文出自 “ptallrights” 博客,请务必保留此出处http://ptallrights.blog.51cto.com/11151122/1793746

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal