python 面向對象
概述:
- 类(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
无论你选择做什么,追求完美的程度决定你成就的高度。
浙公网安备 33010602011771号