首頁 > 軟體

Python詳解如何動態給物件增加屬性和方法

2022-07-21 14:02:29

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動態增加屬性方法內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!


IT145.com E-mail:sddin#qq.com