Python對(duì)象動(dòng)態(tài)得增加屬性和方法
前面我們了解到數(shù)據(jù)封裝、繼承和多態(tài)只是面向?qū)ο蟪绦蛟O(shè)計(jì)中最基礎(chǔ)得3個(gè)概念。
在Python中,面向?qū)ο筮€有很多高級(jí)特性,允許我們寫出非常強(qiáng)大得功能。
python是動(dòng)態(tài)語(yǔ)?,動(dòng)態(tài)編程語(yǔ)?是?級(jí)程序設(shè)計(jì)語(yǔ)?得?個(gè)類別,在計(jì)算機(jī)科學(xué)領(lǐng)域已被?泛應(yīng)?。它是?類在 運(yùn)?時(shí)可以改變其結(jié)構(gòu) 得語(yǔ)? :例如新得函數(shù)、對(duì)象、甚?代碼可以被引進(jìn),已有得函數(shù)可以被刪除或是其他結(jié)構(gòu)上得變化。
動(dòng)態(tài)語(yǔ)??前?常具有活?,例如,我們現(xiàn)在創(chuàng)建一個(gè)人得類,在這個(gè)類里面,定義了兩個(gè)初始屬性name和age
# -*- coding: utf-8 -*-class Person(object): def __init__(self, name=None, age=None): self.name = name self.age = age
現(xiàn)在我們實(shí)例化一個(gè)人,P對(duì)象對(duì)應(yīng)得就是張三這個(gè)人,我們傳入p對(duì)象得兩個(gè)屬性,姓名和年齡,這個(gè)p對(duì)象就好像是自己,我們把自己得姓名和年齡得屬性,掛在自己身上。
>>> p = Person('張三', 20)
接著,此時(shí)出現(xiàn)問題,若我不知道不認(rèn)識(shí)這個(gè)人,例如我在人這個(gè)一個(gè)系統(tǒng)里面,茫茫人海無(wú)意間看到了有這個(gè)p對(duì)象,有點(diǎn)好奇,或者需要查到他一些資料,給到他,但我不熟悉有這個(gè)人,我想看看這個(gè)人是男是女
>>> p.name
張三
>>> # 如果我們這里寫上p.sex就會(huì)存在問題,因?yàn)闆]有這個(gè)人得性別信息
>>> p.sex = '男'
>>> p.sex
男
這時(shí)候就發(fā)現(xiàn)問題了,我們定義得類??沒有sex這個(gè)屬性啊!怎么回事呢?這就是動(dòng)態(tài)語(yǔ)?得魅?和坑! 這? 實(shí)際上就是 動(dòng)態(tài)給實(shí)例綁定屬性!
在運(yùn)行得過程中給類綁定屬性,看下面得例子
>>> p2 = Person('李四', 20)
>>> p2.sex
Traceback (most recent call last):4
.......
AttributeError: Person instance has no attribute 'sex'
>>>
我們嘗試打印P2.sex,發(fā)現(xiàn)報(bào)錯(cuò),P2沒有sex這個(gè)屬性!---- 給P1這個(gè)實(shí)例綁定屬性對(duì)P2這個(gè)實(shí)例不起作?! 那我們要給所有得Person得實(shí)例加上 sex屬性怎么辦呢? 答案就是直接給Person綁定屬性!
>>> Person.sex = None # 給類Person添加一個(gè)屬性
>>> p2 = Person('李四', 20)
>>> print(p.sex) # 如果P1這個(gè)實(shí)例對(duì)象中沒有sex屬性得話,那么就會(huì)訪問它得類屬性
None # 可以看到?jīng)]有出現(xiàn)異常
>>>
我們直接給Person綁定sex這個(gè)屬性,重新實(shí)例化P2后,P2就有sex這個(gè)屬性了! 那么function呢?怎么綁定?
# -*- coding: utf-8 -*-class Person(object): def __init__(self, name, age): self.name = name self.age = age def eat(self): print('吃食物')# 單獨(dú)定義一個(gè)方法def test(self, work): print('%s在%s' % (self.name, work))
>>> P = Person("小明", 24)
>>> p.eat()
eat food
>>> p.run()
Traceback (most recent call last):
......
AttributeError: Person instance has no attribute 'run'>>> import types
>>> p.test = types.MethodType(test, p)
>>> p.test('學(xué)習(xí)')
小明在學(xué)習(xí)
既然給類添加?法,是使? 類名.?法名 = xxxx
那么給對(duì)象添加?個(gè)?法也是類似得 對(duì)象.?法名 = xxxx
看完整代碼,對(duì)類方法,方法,增加綁定:
# -*- coding: utf-8 -*-import typesclass Person(object): num = 0 # 類屬性 def __init__(self, name, age): self.name = name self.age = age# 定義一個(gè)函數(shù)def eat(self, food): print(self.name + '在吃' + food)# 定義一個(gè)類方法@classmethoddef cm(cls): print('這是給Person類動(dòng)態(tài)賦予一個(gè)類函數(shù)')# 定義一個(gè)靜態(tài)方法@staticmethoddef sm(): print('這是給Person類動(dòng)態(tài)賦予一個(gè)一個(gè)靜態(tài)函數(shù)')if __name__ == '__main__': p = Person('張三', 33) # 創(chuàng)建對(duì)象 Person.address = '北京' # 類屬性 # 1.可以給 對(duì)象p 動(dòng)態(tài)得賦予一個(gè)對(duì)象屬性 p.sex = '男' # 對(duì)象屬性 # 2.可以給對(duì)象 p 動(dòng)態(tài)賦予一個(gè)新得對(duì)象函數(shù) p.eat = types.MethodType(eat, p) print(p.eat('牛奶')) # 3. 給Person類動(dòng)態(tài)賦予一個(gè)類函數(shù) Person.cm = cm # 調(diào)用類方法 print(Person.cm()) # 4.給Person類動(dòng)態(tài)賦予一個(gè)靜態(tài)函數(shù) Person.sm = sm # 調(diào)用靜態(tài)方法 print(Person.sm())
那既然有增加,就有刪除
刪除對(duì)象與屬性得方法
del 對(duì)象.屬性名
delattr(對(duì)象, “屬性名”)
我們知道,正常情況下,當(dāng)我們定義了一個(gè)class,創(chuàng)建了一個(gè)class得實(shí)例后,我們可以給該實(shí)例綁定任何屬性和方法,這就是動(dòng)態(tài)語(yǔ)言得靈活性。先定義class:然后嘗試給實(shí)例綁定一個(gè)屬性,還可以綁定一個(gè)方法,但是一個(gè)實(shí)
例方法對(duì)另一個(gè)實(shí)例不起作用,那就得給類整個(gè)類綁定一個(gè)方法或?qū)傩裕@樣所有得實(shí)例都可以調(diào)用
需要注意得是我們得動(dòng)態(tài)語(yǔ)言在運(yùn)行后還能修改得,但是靜態(tài)語(yǔ)言是不可以得,這就會(huì)造成不嚴(yán)謹(jǐn)。
到此這篇關(guān)于Python詳解如何動(dòng)態(tài)給對(duì)象增加屬性和方法得內(nèi)容就介紹到這了,更多相關(guān)Python動(dòng)態(tài)增加屬性方法內(nèi)容請(qǐng)搜索之家以前得內(nèi)容或繼續(xù)瀏覽下面得相關(guān)內(nèi)容希望大家以后多多支持之家!