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!

推薦閱讀: