概述:
- 类(Class): 用来描述具有相同的属性和方法的对象的集合。它定义了该集合中每个对象所共有的属性和方法。对象是类的实例。
- 类变量:类变量在整个实例化的对象中是公用的。类变量定义在类中且在函数体之外。类变量通常不作为实例变量使用。
- 数据成员:类变量或者实例变量, 用于处理类及其实例对象的相关的数据。
- 方法重写:如果从父类继承的方法不能满足子类的需求,可以对其进行改写,这个过程叫方法的覆盖(override),也称为方法的重写。
- 局部变量:定义在方法中的变量,只作用于当前实例的类。
- 实例变量:在类的声明中,属性是用变量来表示的。这种变量就称为实例变量,是在类声明的内部但是在类的其他成员方法之外声明的。
- 继承:即一个派生类(derived class)继承基类(base class)的字段和方法。继承也允许把一个派生类的对象作为一个基类对象对待。例如,有这样一个设计:一个Dog类型的对象派生自Animal类,这是模拟"是一个(is-a)"关系(例图,Dog是一个Animal)。
- 实例化:创建一个类的实例,类的具体对象。
- 方法:类中定义的函数。
- 对象:通过类定义的数据结构实例。对象包括两个数据成员(类变量和实例变量)和方法。
面向对象的三大特性是指:封装、继承和多态。
一、封装
封装,顾名思义就是将内容封装到某个地方,以后再去调用被封装在某处的内容。
所以,在使用面向对象的封装特性时,需要:
- 将内容封装到某处
- 从某处调用被封装的内容
二、继承
继承,面向对象中的继承和现实生活中的继承相同,即:子可以继承父的内容。
对于面向对象的继承来说,其实就是将多个类共有的方法提取到父类中,子类仅需继承父类而不必一一实现每个方法
Python的类如果继承了多个类,那么其寻找方法的方式有两种,分别是:深度优先和广度优先
- 当类是经典类时,多继承情况下,会按照深度优先方式查找
- 当类是新式类时,多继承情况下,会按照广度优先方式查找
三、多态
Pyhon不支持Java和C#这一类强类型语言中多态的写法,但是原生多态,其Python崇尚“鸭子类型”
面向对象的应用场景:
多函数需使用共同的值,如:数据库的增、删、改、查操作都需要连接数据库字符串、主机名、用户名和密码
class SqlHelper: def __init__(self, host, user, pwd): self.host = host self.user = user self.pwd = pwd def 增(self): # 使用主机名、用户名、密码(self.host 、self.user 、self.pwd)打开数据库连接 # do something # 关闭数据库连接 def 删(self): # 使用主机名、用户名、密码(self.host 、self.user 、self.pwd)打开数据库连接 # do something # 关闭数据库连接 def 改(self): # 使用主机名、用户名、密码(self.host 、self.user 、self.pwd)打开数据库连接 # do something # 关闭数据库连接 def 查(self): # 使用主机名、用户名、密码(self.host 、self.user 、self.pwd)打开数据库连接 # do something # 关闭数据库连接# do something Demo
需要创建多个事物,每个事物属性个数相同,但是值的需求
如:张三、李四、杨五,他们都有姓名、年龄、血型,但其都是不相同。即:属性个数相同,但值不相同
class Person: def __init__(self, name ,age ,blood_type): self.name = name self.age = age self.blood_type = blood_type def detail(self): temp = "i am %s, age %s , blood type %s " % (self.name, self.age, self.blood_type) print temp zhangsan = Person('张三', 18, 'A') lisi = Person('李四', 73, 'AB') yangwu = Person('杨五', 84, 'A') Demo
class bar(): def foo(self,connect): print(self.name,self.age,self.gender,connect) h = bar() h.name = 'hua' h.age = 22 h.gender = 'f' h.foo('小呀嘛小二郎') h.foo('ffffff') ****************************************** class person(): def __init__(self,name,age): #構造方法 self.n=name self.a=age self.x='AB' def foo(self): print('%s-%s'% (self.n,self.a)) hua = person('lihuan', 22) hua.foo() yang = person('yangzi' , 24) yang.foo() ************************************** class F: def f1(self): print('爸爸') class S(F): #繼承 def s1(self): print('兒子') obj = S() obj.s1() obj.f1() ******************************** class F: def f1(self): print('爸爸') def f2(self): print('哈哈') class S(F): #繼承 def s1(self): print('兒子') super(S,self).f2() #執行父類的f2方法 F.f1(self) #執行父類的f1方法 def s2(self): print('二二而') obj = S() obj.s1() obj.f2() ********************************** class Foo: def bar(self): print('你好') @staticmethod def sta(): print('哈哈') @staticmethod def stat(a ,b): print(a, b) @classmethod def bbb(cls): #cls類名 print(cls) print('川島穎子') @property def ccc(self): return '加藤鷹' @ccc.setter def ccc(self, val): print(val) @ccc.deleter def ccc(self): print('川島芳子') Foo.sta() Foo.stat('蒼井空', '武藤蘭') Foo.bbb() obj = Foo() r = obj.ccc print(r) obj.ccc = '櫻之海' del obj.ccc ***************************************** class page_name: def __init__(self, current_page): try: p = int(current_page) except Exception as e: p = 1 self.page = p @property def start(self): val = (self.page - 1) * 10 return val @property def end(self): val = self.page * 10 return val li = [] for i in range(1000): li.append(i) while True: p = input('請輸入要查看的頁碼:') obj = page_name(p) print(li[obj.start: obj.end]) **************************************** 異常處理 def fun(): while True: ret = 0 try: li=[11,22] li[888] int('wer') except IndexError as e: print('IndexError' , e) except ValueError as e: print('ValueError', e) except Exception as e: print(e) else: ret =1 print('elese') finally: print('.....') return ret r = fun() if r ==0: print('500') else: pass