python 面向对象

你把自己想象成一个上帝,你要创造一个星球,首先你要把它揉成一个个球,两个直径就能创造一个球

 

class star:
    '''名字(name),赤道直径(equatorial diameter),极直径(polar diameter)'''
    def __init__(self,name,eqDiameter,poDiameter):
        self.name=name
        self.eqDiameter=eqDiameter    #赤道直径
        self.poDiameter=poDiameter    #极直径
        self.show()
    def show(self):
        print("A spin star %s,this ed is %s,pd is %s"%(self.name,self.eqDiameter,self.poDiameter))

earth=star("earth",24901,24859)

得出:A spin star earth created,this ed is 24901,pd is 24859

 

 

类和对象的关系:

对象是类的实例

继承:

B类继承A类,A类的可以继承的成员,都是B类的,如果A类有的成员,B类也有,优先使用B类的成员,如果B类的对象要使用A类的成员,要用到多态。

称B类继承A类,B类是由A类派生的,A类是B类父类或基类,B类是A类的子类或派生类,判断方法:issubclass(C(子),B(父))

多态:多种形态------就是子类的对象可以使用父类的成员,这个成员子类里面已经有的,对象不满足子类的这个成员,去找它父类的方法

 多个类的继承关系:

多继承实例:

python类成员:

1,字段:静态字段/普通字段

2,方法:静态方法/普通方法/类方法/特殊方法

3,属性

4,成员修饰符

5,特殊方法

 

类的成员是可以权限控制的,python的类权限只有私有(private)和共有(public),私有的对象的标志是成员前面加__

class Province:
    country="中国"      #静态变量
    __party="Comunity"      #私有的静态成员

私有成员只能当前类内部使用,不能给对象和继承类使用

 

字段:

字段就是数据成员,静态字段储存在类里,普通字段储存在对象里,每个对象创建都需要开辟普通字段的内存空间,静态字段只需要呆在类的空间里,所以当普通字段太多的时候,如果确定某一个变量初始是固定的情况下,可以把这个变量变成静态字段

 

方法:

方法都属于类,普通方法由对象去执行,静态方法和类方法由类执行,不创建对象,省空间,类方法指定当前类

@staticmethod   定义静态方法

@classmethod    定义类方法

 

class Province:
    country="中国"      #静态变量
    __party="Comunity"      #私有的静态成员
    def __init__(self,name):
        self.Myparty=self.__party      #普通变量
        self.__name=name    #私有,不能继承
        self.f1()
        self.__f1()
    def show(self):      #普通对象,由对象去调用
        print(self.__name)
    @staticmethod       #静态方法,通过类去调用,可以类内部使用
    def f1():
        print("fl")

    @staticmethod
    def __f1(self):     #私有的静态方法
        print("private fl")
    @classmethod        #类方法
    def f2(cls):
        print(cls)

 

属性成员:

看上去像方法,用起来像字段,装饰器:@property

属性可以打印值,赋值,删除值

 

class profact:
    '''改造工厂'''
    @property      #属性
    def f3(self):
        return 10
    @f3.setter     #可以给属性赋值
    def f3(self,value):
        print(value)
    @f3.deleter     #删除属性
    def f3(self):
        print("deleted")

a=profact()
result=a.f3  #调用的是property下的f3
a.f3=12      #调用@f3.setter下的f3
del a.f3     #调用@f3.deleter下的f3   

 

 

特殊成员:

函数

说明

举例

__init__

构造函数,创造对象

 

__del__

析构函数,垃圾回收

 

__call__

把对象当成函数调用,当对象后面有()时候调用

a=A()

print(a())

__str__

Print调用

print(a)

__add__

This + other

 

__sub__

This - other

 

__iter__

迭代时自动调用,可以用yield配合

 

__getitem__

接收key,key接收切片1:2:3对应key.start

Key.stop

Key.step

a[“ddd”]

__setitem

接收key和value

a[“ddd”]=”dddd”

__delitem__

接收key

del a[“ddd”]

 

异常处理:

当用户创建一个目录的时候,不能保证目录不存在

当用户删除目录的时候,不能保证目录存在,也不能保证该目录是否为空

以上这些情况都会导致异常出现,会导致程序终止,而这些本来明明不是问题的问题导致了程序终止,像这些我们明知道会报错的程序就可以用异常处理,显示友好的错误提示,提高用户体验

 

import os
os.mkdir("kkk")    #kkk目录存在的情况下执行

Traceback (most recent call last):
  File "F:/project/pysession/day08/异常处理.py", line 37, in <module>
    os.mkdir("kkk")
FileExistsError: [WinError 183] 当文件已存在时,无法创建该文件。: 'kkk'

 

改造后:

import os
try:
    path="kkk"
    os.mkdir(path)
except FileExistsError:
    print("%s目录已经存在"%path)

 

像上面确定错误类型的可以直接用错误类型,如果无法判断错误类型也可以用Exception:

import os
try:
    path="kkk"
    os.mkdir(path)
except Exception:
    print("%s目录已经存在"%path)

 

一个完整的捕获:

import os
try:
    path="kkk"
    os.rmdir(path)
except FileNotFoundError:
    print("%s目录不存在"%path)
except OSError:
    print("%s目录不为空"%path)
except Exception:
    print("%s目录无法错误" % path)

else:        #仅在正确的情况下执行
    print("%s目录成功删除"%path)
finally:        #无论错误还是正确,都执行
    print("目录删除到此结束")

 

我可以自己制造错误 raise <错误类型>("<错误信息>"):

raise Exception("出错了")
得出错误:
Exception: 出错了

想要捕获错误,并且显错误信息:

try:
    raise Exception("出错了")
except Exception as errormsg:
    print(errormsg)

 

自己定义错误类型:

class MyException(Exception):
    def __init__(self,errormsg):
        self.errormsg=errormsg

    def __str__(self):
        return self.errormsg
raise MyException("出错了")
得出:__main__.MyException: 出错了

 

posted on 2016-09-13 12:44  euewrqe  阅读(484)  评论(0编辑  收藏  举报