一爽冕、面向?qū)ο?/h1>
編程思想:
1.面向過(guò)程編程 ---> 算法,邏輯(數(shù)學(xué)邏輯)
2.函數(shù)式編程 ---> 函數(shù),模塊
3.面向?qū)ο缶幊?---> 類(lèi)和對(duì)象 (生活)
二充石、類(lèi)的聲明
1.什么是類(lèi)和對(duì)象
類(lèi) - 是擁有相同屬性和相同功能的對(duì)象的集合(抽象的)
對(duì)象 - 就是類(lèi)的實(shí)例(具體的)
從生活的角度來(lái)看類(lèi)和對(duì)象
如果說(shuō)人是一個(gè)類(lèi), 余婷就是一個(gè)對(duì)象霞玄,駱昊也是一個(gè)對(duì)象
如果說(shuō)電腦是一個(gè)類(lèi)骤铃,我桌上的這臺(tái)mac就是一個(gè)對(duì)象
如果水杯是一個(gè)類(lèi),具體的某個(gè)水杯才是這個(gè)類(lèi)的對(duì)象
如果車(chē)是一個(gè)類(lèi)坷剧,汽車(chē)惰爬、自行車(chē)、摩托車(chē)等這些是這個(gè)類(lèi)的子類(lèi)惫企, 具體的某一輛車(chē)才是對(duì)象
2.類(lèi)的聲明
格式:
class 類(lèi)名(父類(lèi)列表):
類(lèi)的說(shuō)明文檔
類(lèi)的內(nèi)容
說(shuō)明:
class -> python中聲明類(lèi)的關(guān)鍵字
類(lèi)名 -> 標(biāo)識(shí)符,不能是關(guān)鍵字;類(lèi)名使用駝峰式命名撕瞧,并且首字母大寫(xiě);見(jiàn)名知義
駝峰式命名:如果一個(gè)名字由多個(gè)單詞組成,第一個(gè)單詞首字母小寫(xiě)狞尔,后面每個(gè)單詞首字母大寫(xiě).丛版。例如:userName
PEP8命名規(guī)范:如果一個(gè)名字由多個(gè)單詞組成,所有字母小寫(xiě)偏序,多個(gè)單詞之間用下劃線隔開(kāi)页畦。例如:user_name
(父類(lèi)列表) -> 繼承語(yǔ)法,讓聲明的類(lèi)繼承括號(hào)中的父類(lèi)禽车。這個(gè)結(jié)構(gòu)可以省略寇漫,讓當(dāng)前類(lèi)繼承python的基類(lèi):object
: -> 固定結(jié)構(gòu)
類(lèi)的說(shuō)明文檔 -> 注釋?zhuān)瑢?duì)類(lèi)進(jìn)行說(shuō)明刊殉。
類(lèi)的內(nèi)容 -> 包含屬性(變量)和方法(函數(shù))。方法:聲明在類(lèi)中的函數(shù)
# 聲明Person類(lèi)州胳,吃飯和睡覺(jué)
class Person:
"""人類(lèi)"""
def eat(self):
print('吃飯记焊!')
def sleep(self):
print('睡覺(jué)!')
3.對(duì)象的聲明
格式:
對(duì)象名 = 類(lèi)名()
對(duì)象名 -> 變量名
類(lèi)名 -> 必須是聲明過(guò)的類(lèi)
# 聲明了Perosn類(lèi)的對(duì)象p1
p1 = Person()
p2 = Person()
三栓撞、對(duì)象方法
1.類(lèi)的內(nèi)容包含屬性和方法, 方法分為對(duì)象方法遍膜、類(lèi)方法和靜態(tài)方法
對(duì)象方法:直接聲明在類(lèi)中的函數(shù)就是對(duì)象方法。對(duì)象方法都有一個(gè)默認(rèn)參數(shù)self, 通過(guò)對(duì)象來(lái)調(diào)用
對(duì)象方法的調(diào)用: 對(duì)象.方法名()瓤湘。調(diào)用對(duì)象方法的時(shí)候瓢颅,不需要給默認(rèn)參數(shù)self傳參。系統(tǒng)會(huì)自動(dòng)將當(dāng)前對(duì)象傳遞給self 弛说。
self: 誰(shuí)調(diào)用當(dāng)前的對(duì)象方法挽懦,self就指向誰(shuí)。self就是當(dāng)前類(lèi)的對(duì)象木人,類(lèi)的對(duì)象能做的事情信柿,self都能做
# 聲明類(lèi)
class Person:
"""人類(lèi)"""
# 對(duì)象方法eat
def eat(self, name):
# self = p1, name = '小明'
print('self:',self)
print('吃飯!')
self.sleep()
def sleep(self):
print('s_self', self)
print('睡覺(jué)')
# 聲明對(duì)象
p1 = Person()
print('p1:', p1)
p1.eat('小明')
# p1.sleep()
p2 = Person()
print('p2:', p2)
p2.eat('小紅')
四醒第、構(gòu)造方法和init方法
1.構(gòu)造方法
構(gòu)造方法就是函數(shù)名和類(lèi)名一樣的方法渔嚷,作用是用來(lái)創(chuàng)建對(duì)象的。
聲明類(lèi)的時(shí)候稠曼,系統(tǒng)會(huì)自動(dòng)為這個(gè)類(lèi)創(chuàng)建對(duì)應(yīng)構(gòu)造方法
創(chuàng)建對(duì)象的過(guò)程:調(diào)用構(gòu)造方法在內(nèi)存中開(kāi)辟空間創(chuàng)建對(duì)象形病,并且會(huì)自動(dòng)調(diào)用init方法去對(duì)這個(gè)對(duì)象進(jìn)行初始化,最后將創(chuàng)建好的對(duì)象的地址返回
2.__init__方法
對(duì)象方法,不需要手動(dòng)調(diào)用霞幅,創(chuàng)建完對(duì)象后漠吻,會(huì)被自動(dòng)調(diào)用
class Dog:
"""??類(lèi)"""
def __init__(self):
print(self)
print('init方法')
dog1 = Dog()
print(dog1)
dog2 = Dog()
3.帶參其他參數(shù)的init方法
__init__方法的參數(shù)要通過(guò)構(gòu)造方法來(lái)傳。(構(gòu)造方法的實(shí)參蝗岖,會(huì)傳遞給init方法的形參)
class Person:
def __init__(self, name='', age=0):
print(name, age)
p1 = Person('小紅', 20)
p2 = Person('小明')
p3 = Person(age=10)
五侥猩、對(duì)象的屬性
類(lèi)的內(nèi)容包含屬性和方法,屬性又分為對(duì)象屬性和類(lèi)的字段
屬性:用來(lái)在類(lèi)中去保存數(shù)據(jù)的變量抵赢。
對(duì)象屬性:屬性的值會(huì)因?yàn)閷?duì)象不同而不同欺劳,這種屬性就需要聲明成對(duì)象屬性,例如:人的名字铅鲤,人的年齡等
對(duì)象屬性要通過(guò)對(duì)象來(lái)使用
1.對(duì)象屬性的聲明(重點(diǎn)划提!)
a.必須聲明在init方法中
b.聲明格式:self.屬性 = 初值
2.使用對(duì)象屬性: 對(duì)象.屬性
# 聲明一個(gè)人類(lèi),要求有名字邢享,年齡和性別屬性
class Person:
def __init__(self):
self.name = '張三'
self.age = 18
self.sex = '男'
p1 = Person()
print(p1.name)
p2 = Person()
print(p2.name)
3.創(chuàng)建對(duì)象的時(shí)候可以給對(duì)象屬性賦值
class Person2:
def __init__(self, name1, age1=0, sex1='girl'):
self.name = name1
self.age = age1
self.sex = sex1
self.id = '0001'
p1 = Person2('小明', 30, '女')
print(p1.name)
p1.name = 'XiaoMing' # 可以修改屬性的值
print(p1.name)
p1.id = 'p0001'
print(p1.id)
p2 = Person2('小紅', 18, '男')
print(p2.name)
p3 = Person2('小花')
print(p3.name)
六鹏往、對(duì)象屬性的增刪改查
class Student:
def __init__(self, name1='', age1=0, study_id1='001'):
self.name = name1
self.age = age1
self.study_id = study_id1
stu1 = Student('小明')
stu2 = Student('小紅', 18)
方法1:對(duì)象.屬性 --> 獲取指定屬性值,屬性不存在會(huì)報(bào)錯(cuò)
print(stu1.name)
# print(stu1.name2) # AttributeError: 'Student' object has no attribute 'name2'
方法2:getattr(對(duì)象, 屬性名, 默認(rèn)值) -> 獲取指定屬性值骇塘,如果設(shè)置了默認(rèn)值當(dāng)屬性不存在的時(shí)候不會(huì)報(bào)錯(cuò)伊履, 并且會(huì)將默認(rèn)值作為結(jié)果韩容。(如果沒(méi)有設(shè)置默認(rèn)值,屬性不存在還是會(huì)報(bào)錯(cuò))
print(getattr(stu1, 'name'))
print(getattr(stu1, 'name2', '張三'))
方法3:對(duì)象.getattribute(屬性名) -> 獲取指定屬性值.屬性不存在會(huì)報(bào)錯(cuò)
print(stu1.__getattribute__('study_id'))
# print(stu1.__getattribute__('study_id2')) # AttributeError: 'Student' object has no attribute 'study_id2'
2.增/改(給對(duì)象添加屬性)
注意:給對(duì)象添加屬性唐瀑,只能添加到當(dāng)前對(duì)象中群凶。不會(huì)影響當(dāng)前類(lèi)的其他對(duì)象
方法1:對(duì)象.屬性 = 值 (屬性不存在的時(shí)候增加,存在的是就是修改)
方法2:setattr(對(duì)象,屬性名,屬性值)
方法3:對(duì)象.setattr(屬性名,屬性值)
# 添加
stu1.sex = '男'
print(stu1.sex)
# 修改
stu1.name = '李四'
print(stu1.name)
# 修改
setattr(stu1, 'name', '娜美')
print(stu1.name)
# 添加
setattr(stu1, 'name2', '寶兒姐')
print(stu1.name2)
3.刪(刪除對(duì)象屬性)
注意:刪除只刪除當(dāng)前對(duì)象的屬性,對(duì)當(dāng)前類(lèi)的其他對(duì)象沒(méi)有影響
方法一:del 對(duì)象.屬性
方法二:delattr(對(duì)象, 屬性名)
方法三: 對(duì)象.delattr(屬性名)
del stu1.age
# print(stu1.age)
print(stu1.sex)
delattr(stu1, 'sex')
# print(stu1.sex)
stu1.__delattr__('name')
七哄辣、對(duì)象的使用
class Student:
def __init__(self, name, age, score):
self.name = name
self.age = age
self.score = score
# 定制當(dāng)前類(lèi)對(duì)象的打印格式请梢,函數(shù)的返回值必須是字符串
def __str__(self):
return str(self.__dict__)
# 1.將對(duì)象給別的變量賦值
stu1 = Student('xiaoHua', 18, 90)
stu2 = stu1 # 賦對(duì)象地址
stu3 = copy.copy(stu1) # 產(chǎn)生新的對(duì)象,將新的地址賦值
stu1.name = '張三'
print(stu2.name)
print(stu3.name)
# 2.將對(duì)象作為列表的元素
students = [Student('小明', 23, 89), stu3, Student('小紅', 10, 67)]
# 找到列表students中成績(jī)最好的學(xué)生的名字
max1 = students[0].score
name = students[0].name
for stu in students:
if stu.score > max1:
max1 = stu.score
name = stu.name
print(name, max1)
# 對(duì)列表中的學(xué)生按年齡從小到大排序
students.sort(key=lambda item: item.age)
for stu in students:
print(stu)
max1 = max(students, key=lambda item: item.score)
print('max:',max1)
# 1.根據(jù)姓名查找指定學(xué)生的信息力穗。2.根據(jù)姓名修改執(zhí)行的學(xué)生的年齡
name = input('請(qǐng)輸入學(xué)生的名字:')
for stu in students:
if stu.name == name:
stu.age = 18
print(stu)
八毅弧、slots魔法
1.類(lèi)的字段
屬性:對(duì)象屬性,類(lèi)的字段
類(lèi)的字段: 聲明在類(lèi)里面当窗,函數(shù)外面的變量就是類(lèi)的字段够坐。使用的時(shí)候要通過(guò)類(lèi)來(lái)使用:類(lèi).字段
2.slots: 用來(lái)約束當(dāng)前類(lèi)的對(duì)象的屬性有哪些
class Dog:
# num就是類(lèi)的字段
num = 10
__slots__ = ('color', 'name', 'type', 'sex', 'price', 'age')
def __init__(self, color, name, type):
self.color = color
self.name = name
self.type = type
self.sex = '公的'
print(Dog.num)
Dog.num = 100
print(Dog.num)
dog1 = Dog('黃色', '大黃', '土狗')
# dog1.neme = '財(cái)財(cái)'
# print(dog1.name)
dog1.age = 3
九、內(nèi)置類(lèi)屬性
class Person:
"""人類(lèi)"""
# 類(lèi)的字段
num = 61
# 對(duì)象屬性
def __init__(self, name, age, sex):
self.name = name
self.age = age
self.sex = sex
# 對(duì)象方法
def run(self):
print('%s在跑' % self.name)
def __str__(self):
return '<<'+self.__class__.__module__+'.'+self.__class__.__name__+\
'object at ' + hex(id(self))+'>>'
p1 = Person('小明', 18, '男')
格式:
class 類(lèi)名(父類(lèi)列表):
類(lèi)的說(shuō)明文檔
類(lèi)的內(nèi)容
# 聲明Person類(lèi)州胳,吃飯和睡覺(jué)
class Person:
"""人類(lèi)"""
def eat(self):
print('吃飯记焊!')
def sleep(self):
print('睡覺(jué)!')
# 聲明了Perosn類(lèi)的對(duì)象p1
p1 = Person()
p2 = Person()
# 聲明類(lèi)
class Person:
"""人類(lèi)"""
# 對(duì)象方法eat
def eat(self, name):
# self = p1, name = '小明'
print('self:',self)
print('吃飯!')
self.sleep()
def sleep(self):
print('s_self', self)
print('睡覺(jué)')
# 聲明對(duì)象
p1 = Person()
print('p1:', p1)
p1.eat('小明')
# p1.sleep()
p2 = Person()
print('p2:', p2)
p2.eat('小紅')
class Dog:
"""??類(lèi)"""
def __init__(self):
print(self)
print('init方法')
dog1 = Dog()
print(dog1)
dog2 = Dog()
class Person:
def __init__(self, name='', age=0):
print(name, age)
p1 = Person('小紅', 20)
p2 = Person('小明')
p3 = Person(age=10)
# 聲明一個(gè)人類(lèi),要求有名字邢享,年齡和性別屬性
class Person:
def __init__(self):
self.name = '張三'
self.age = 18
self.sex = '男'
p1 = Person()
print(p1.name)
p2 = Person()
print(p2.name)
class Person2:
def __init__(self, name1, age1=0, sex1='girl'):
self.name = name1
self.age = age1
self.sex = sex1
self.id = '0001'
p1 = Person2('小明', 30, '女')
print(p1.name)
p1.name = 'XiaoMing' # 可以修改屬性的值
print(p1.name)
p1.id = 'p0001'
print(p1.id)
p2 = Person2('小紅', 18, '男')
print(p2.name)
p3 = Person2('小花')
print(p3.name)
class Student:
def __init__(self, name1='', age1=0, study_id1='001'):
self.name = name1
self.age = age1
self.study_id = study_id1
stu1 = Student('小明')
stu2 = Student('小紅', 18)
print(stu1.name)
# print(stu1.name2) # AttributeError: 'Student' object has no attribute 'name2'
print(getattr(stu1, 'name'))
print(getattr(stu1, 'name2', '張三'))
print(stu1.__getattribute__('study_id'))
# print(stu1.__getattribute__('study_id2')) # AttributeError: 'Student' object has no attribute 'study_id2'
# 添加
stu1.sex = '男'
print(stu1.sex)
# 修改
stu1.name = '李四'
print(stu1.name)
# 修改
setattr(stu1, 'name', '娜美')
print(stu1.name)
# 添加
setattr(stu1, 'name2', '寶兒姐')
print(stu1.name2)
del stu1.age
# print(stu1.age)
print(stu1.sex)
delattr(stu1, 'sex')
# print(stu1.sex)
stu1.__delattr__('name')
class Student:
def __init__(self, name, age, score):
self.name = name
self.age = age
self.score = score
# 定制當(dāng)前類(lèi)對(duì)象的打印格式请梢,函數(shù)的返回值必須是字符串
def __str__(self):
return str(self.__dict__)
# 1.將對(duì)象給別的變量賦值
stu1 = Student('xiaoHua', 18, 90)
stu2 = stu1 # 賦對(duì)象地址
stu3 = copy.copy(stu1) # 產(chǎn)生新的對(duì)象,將新的地址賦值
stu1.name = '張三'
print(stu2.name)
print(stu3.name)
# 2.將對(duì)象作為列表的元素
students = [Student('小明', 23, 89), stu3, Student('小紅', 10, 67)]
# 找到列表students中成績(jī)最好的學(xué)生的名字
max1 = students[0].score
name = students[0].name
for stu in students:
if stu.score > max1:
max1 = stu.score
name = stu.name
print(name, max1)
# 對(duì)列表中的學(xué)生按年齡從小到大排序
students.sort(key=lambda item: item.age)
for stu in students:
print(stu)
max1 = max(students, key=lambda item: item.score)
print('max:',max1)
# 1.根據(jù)姓名查找指定學(xué)生的信息力穗。2.根據(jù)姓名修改執(zhí)行的學(xué)生的年齡
name = input('請(qǐng)輸入學(xué)生的名字:')
for stu in students:
if stu.name == name:
stu.age = 18
print(stu)
class Dog:
# num就是類(lèi)的字段
num = 10
__slots__ = ('color', 'name', 'type', 'sex', 'price', 'age')
def __init__(self, color, name, type):
self.color = color
self.name = name
self.type = type
self.sex = '公的'
print(Dog.num)
Dog.num = 100
print(Dog.num)
dog1 = Dog('黃色', '大黃', '土狗')
# dog1.neme = '財(cái)財(cái)'
# print(dog1.name)
dog1.age = 3
class Person:
"""人類(lèi)"""
# 類(lèi)的字段
num = 61
# 對(duì)象屬性
def __init__(self, name, age, sex):
self.name = name
self.age = age
self.sex = sex
# 對(duì)象方法
def run(self):
print('%s在跑' % self.name)
def __str__(self):
return '<<'+self.__class__.__module__+'.'+self.__class__.__name__+\
'object at ' + hex(id(self))+'>>'
p1 = Person('小明', 18, '男')
屬性名 | 作用 | 舉例 |
---|---|---|
類(lèi).__name__ | 獲取當(dāng)前類(lèi)的名字 | print(Person.__name__) |
類(lèi).__doc__ | 獲取類(lèi)的說(shuō)明文檔 | print(Person.__doc__) |
對(duì)象.__class__ | 獲取對(duì)象的類(lèi), 類(lèi)能做的事情超全,他都可以做 | my_class = p1.__class__ |
類(lèi).__dict__ | 獲取當(dāng)前類(lèi)的所有類(lèi)的字段和其對(duì)應(yīng)的值咆霜,以字典的形式返回(了解) | print(Person.__dict__) |
對(duì)象.__dict__ | 獲取當(dāng)前對(duì)象所有的屬性和其對(duì)應(yīng)的值,以字典的形式返回 | print(p1.__dict__) |
類(lèi).__module__ | 獲取當(dāng)前類(lèi)所在的模塊名 | print(Person.__module__) |
類(lèi).__bases__ | 獲取當(dāng)前類(lèi)的父類(lèi), 返回的是一個(gè)元祖嘶朱,元祖的元素是類(lèi) | print(Person.__bases__) |