Python詳解如何動態給對象增加屬性和方法
Python對象動態的增加屬性和方法
前面我們瞭解到數據封裝、繼承和多態隻是面向對象程序設計中最基礎的3個概念。
在Python中,面向對象還有很多高級特性,允許我們寫出非常強大的功能。
python是動態語⾔,動態編程語⾔是⾼級程序設計語⾔的⼀個類別,在計算機科學領域已被⼴泛應⽤。它是⼀類在 運⾏時可以改變其結構 的語⾔ :例如新的函數、對象、甚⾄代碼可以被引進,已有的函數可以被刪除或是其他結構上的變化。
動態語⾔⽬前⾮常具有活⼒,例如,我們現在創建一個人的類,在這個類裡面,定義瞭兩個初始屬性name和age
# -*- coding: utf-8 -*- class Person(object): def __init__(self, name=None, age=None): self.name = name self.age = age
現在我們實例化一個人,P對象對應的就是張三這個人,我們傳入p對象的兩個屬性,姓名和年齡,這個p對象就好像是自己,我們把自己的姓名和年齡的屬性,掛在自己身上。
>>> p = Person('張三', 20)
接著,此時出現問題,若我不知道不認識這個人,例如我在人這個一個系統裡面,茫茫人海無意間看到瞭有這個p對象,有點好奇,或者需要查到他一些資料,給到他,但我不熟悉有這個人,我想看看這個人是男是女
>>> p.name
張三
>>> # 如果我們這裡寫上p.sex就會存在問題,因為沒有這個人的性別信息
>>> p.sex = '男'
>>> p.sex
男
這時候就發現問題瞭,我們定義的類⾥⾯沒有sex這個屬性啊!怎麼回事呢?這就是動態語⾔的魅⼒和坑! 這⾥ 實際上就是 動態給實例綁定屬性!
在運行的過程中給類綁定屬性,看下面的例子
>>> p2 = Person('李四', 20)
>>> p2.sex
Traceback (most recent call last):4
…….
AttributeError: Person instance has no attribute 'sex'
>>>
我們嘗試打印P2.sex,發現報錯,P2沒有sex這個屬性!—- 給P1這個實例綁定屬性對P2這個實例不起作⽤! 那我們要給所有的Person的實例加上 sex屬性怎麼辦呢? 答案就是直接給Person綁定屬性!
>>> Person.sex = None # 給類Person添加一個屬性
>>> p2 = Person('李四', 20)
>>> print(p.sex) # 如果P1這個實例對象中沒有sex屬性的話,那麼就會訪問它的類屬性
None # 可以看到沒有出現異常
>>>
我們直接給Person綁定sex這個屬性,重新實例化P2後,P2就有sex這個屬性瞭! 那麼function呢?怎麼綁定?
# -*- coding: utf-8 -*- class Person(object): def __init__(self, name, age): self.name = name self.age = age def eat(self): print('吃食物') # 單獨定義一個方法 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('學習')
小明在學習
既然給類添加⽅法,是使⽤ 類名.⽅法名 = xxxx
那麼給對象添加⼀個⽅法也是類似的 對象.⽅法名 = xxxx
看完整代碼,對類方法,方法,增加綁定:
# -*- coding: utf-8 -*- import types class Person(object): num = 0 # 類屬性 def __init__(self, name, age): self.name = name self.age = age # 定義一個函數 def eat(self, food): print(self.name + '在吃' + food) # 定義一個類方法 @classmethod def cm(cls): print('這是給Person類動態賦予一個類函數') # 定義一個靜態方法 @staticmethod def sm(): print('這是給Person類動態賦予一個一個靜態函數') if __name__ == '__main__': p = Person('張三', 33) # 創建對象 Person.address = '北京' # 類屬性 # 1.可以給 對象p 動態的賦予一個對象屬性 p.sex = '男' # 對象屬性 # 2.可以給對象 p 動態賦予一個新的對象函數 p.eat = types.MethodType(eat, p) print(p.eat('牛奶')) # 3. 給Person類動態賦予一個類函數 Person.cm = cm # 調用類方法 print(Person.cm()) # 4.給Person類動態賦予一個靜態函數 Person.sm = sm # 調用靜態方法 print(Person.sm())
那既然有增加,就有刪除
刪除對象與屬性的方法
del 對象.屬性名
delattr(對象, “屬性名”)
我們知道,正常情況下,當我們定義瞭一個class,創建瞭一個class的實例後,我們可以給該實例綁定任何屬性和方法,這就是動態語言的靈活性。先定義class:然後嘗試給實例綁定一個屬性,還可以綁定一個方法,但是一個實
例方法對另一個實例不起作用,那就得給類整個類綁定一個方法或屬性,這樣所有的實例都可以調用
需要註意的是我們的動態語言在運行後還能修改的,但是靜態語言是不可以的,這就會造成不嚴謹。
到此這篇關於Python詳解如何動態給對象增加屬性和方法的文章就介紹到這瞭,更多相關Python動態增加屬性方法內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- 基於tensorflow __init__、build 和call的使用小結
- python 特殊屬性及方法詳細解析
- 基於Python 函數和方法的區別說明
- 詳解Python中下劃線的5種含義
- Python中super().__init__()測試以及理解