Python詳解如何動(dòng)態(tài)給對(duì)象增加屬性和方法
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)問(wèn)題,若我不知道不認(rèn)識(shí)這個(gè)人,例如我在人這個(gè)一個(gè)系統(tǒng)里面,茫茫人海無(wú)意間看到了有這個(gè)p對(duì)象,有點(diǎn)好奇,或者需要查到他一些資料,給到他,但我不熟悉有這個(gè)人,我想看看這個(gè)人是男是女
>>> p.name
張三
>>> # 如果我們這里寫上p.sex就會(huì)存在問(wèn)題,因?yàn)闆](méi)有這個(gè)人的性別信息
>>> p.sex = '男'
>>> p.sex
男
這時(shí)候就發(fā)現(xiàn)問(wèn)題了,我們定義的類??沒(méi)有sex這個(gè)屬性?。≡趺椿厥履??這就是動(dòng)態(tài)語(yǔ)?的魅?和坑! 這? 實(shí)際上就是 動(dòng)態(tài)給實(shí)例綁定屬性!
在運(yùn)行的過(guò)程中給類綁定屬性,看下面的例子
>>> 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沒(méi)有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ì)象中沒(méi)有sex屬性的話,那么就會(huì)訪問(wèn)它的類屬性
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 types
class 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è)類方法
@classmethod
def cm(cls):
print('這是給Person類動(dòng)態(tài)賦予一個(gè)類函數(shù)')
# 定義一個(gè)靜態(tài)方法
@staticmethod
def 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ì)象增加屬性和方法的文章就介紹到這了,更多相關(guān)Python動(dòng)態(tài)增加屬性方法內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Python?中?Pandas?文件操作和讀取?CSV?參數(shù)詳解
CSV?又稱逗號(hào)分隔值文件,是一種簡(jiǎn)單的文件格式,以特定的結(jié)構(gòu)來(lái)排列表格數(shù)據(jù),這篇文章主要介紹了Python?之?Pandas?文件操作和讀取?CSV?參數(shù)詳解,需要的朋友可以參考下2023-03-03
解決pycharm上的jupyter notebook端口被占用問(wèn)題
今天小編就為大家分享一篇解決pycharm上的jupyter notebook端口被占用問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-12-12
python實(shí)現(xiàn)數(shù)值積分的Simpson方法實(shí)例分析
這篇文章主要介紹了python實(shí)現(xiàn)數(shù)值積分的Simpson方法,實(shí)例分析了Python實(shí)現(xiàn)積分運(yùn)算的相關(guān)技巧,需要的朋友可以參考下2015-06-06
tkinter如何實(shí)現(xiàn)打開(kāi)文件對(duì)話框并獲取文件絕對(duì)路徑
這篇文章主要介紹了tkinter實(shí)現(xiàn)打開(kāi)文件對(duì)話框并獲取文件絕對(duì)路徑問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-01-01
Python實(shí)現(xiàn)Logger打印功能的方法詳解
最近工作中遇到了打印的需求,通過(guò)查找相關(guān)的資料發(fā)現(xiàn)Python中Logger可以很好的實(shí)現(xiàn)打印,所以下面這篇文章主要給大家介紹了關(guān)于Python如何實(shí)現(xiàn)Logger打印功能的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考下。2017-09-09
django中模板繼承與ModelForm實(shí)例詳解
ModelForm類是form是組件中Form的一個(gè)子類,所以也是處理表單的,下面這篇文章主要給大家介紹了關(guān)于django中模板繼承與ModelForm的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-04-04
把MySQL表結(jié)構(gòu)映射為Python中的對(duì)象的教程
這篇文章主要介紹了簡(jiǎn)單地把MySQL表結(jié)構(gòu)映射為Python中的對(duì)象的方法,用到了Python中的SQLAlchemy庫(kù),需要的朋友可以參考下2015-04-04
pandas分組排序 如何獲取第二大的數(shù)據(jù)
這篇文章主要介紹了pandas分組排序 獲取第二大的數(shù)據(jù)的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2021-03-03

