亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Python深入學(xué)習(xí)之對(duì)象的屬性

 更新時(shí)間:2014年08月31日 14:57:41   投稿:junjie  
這篇文章主要介紹了Python深入學(xué)習(xí)之對(duì)象的屬性,本文從較深的層次講解對(duì)象屬性的內(nèi)部運(yùn)行方式,需要的朋友可以參考下

Python一切皆對(duì)象(object),每個(gè)對(duì)象都可能有多個(gè)屬性(attribute)。Python的屬性有一套統(tǒng)一的管理方案。

屬性的__dict__系統(tǒng)

對(duì)象的屬性可能來(lái)自于其類(lèi)定義,叫做類(lèi)屬性(class attribute)。類(lèi)屬性可能來(lái)自類(lèi)定義自身,也可能根據(jù)類(lèi)定義繼承來(lái)的。一個(gè)對(duì)象的屬性還可能是該對(duì)象實(shí)例定義的,叫做對(duì)象屬性(object attribute)。

對(duì)象的屬性?xún)?chǔ)存在對(duì)象的__dict__屬性中。__dict__為一個(gè)詞典,鍵為屬性名,對(duì)應(yīng)的值為屬性本身。我們看下面的類(lèi)和對(duì)象。chicken類(lèi)繼承自bird類(lèi),而summer為chicken類(lèi)的一個(gè)對(duì)象。

復(fù)制代碼 代碼如下:

class bird(object):
    feather = True

class chicken(bird):
    fly = False
    def __init__(self, age):
        self.age = age

summer = chicken(2)

print(bird.__dict__)
print(chicken.__dict__)
print(summer.__dict__)


 

下面為我們的輸出結(jié)果:

復(fù)制代碼 代碼如下:

{'__dict__': <attribute '__dict__' of 'bird' objects>, '__module__': '__main__', '__weakref__': <attribute '__weakref__' of 'bird' objects>, 'feather': True, '__doc__': None}


{'fly': False, '__module__': '__main__', '__doc__': None, '__init__': <function __init__ at 0x2b91db476d70>}


{'age': 2}

第一行為bird類(lèi)的屬性,比如feather。第二行為chicken類(lèi)的屬性,比如fly和__init__方法。第三行為summer對(duì)象的屬性,也就是age。有一些屬性,比如__doc__,并不是由我們定義的,而是由Python自動(dòng)生成。此外,bird類(lèi)也有父類(lèi),是object類(lèi)(正如我們的bird定義,class bird(object))。這個(gè)object類(lèi)是Python中所有類(lèi)的父類(lèi)。

可以看到,Python中的屬性是分層定義的,比如這里分為object/bird/chicken/summer這四層。當(dāng)我們需要調(diào)用某個(gè)屬性的時(shí)候,Python會(huì)一層層向上遍歷,直到找到那個(gè)屬性。(某個(gè)屬性可能出現(xiàn)再不同的層被重復(fù)定義,Python向上的過(guò)程中,會(huì)選取先遇到的那一個(gè),也就是比較低層的屬性定義)。

當(dāng)我們有一個(gè)summer對(duì)象的時(shí)候,分別查詢(xún)summer對(duì)象、chicken類(lèi)、bird類(lèi)以及object類(lèi)的屬性,就可以知道summer對(duì)象所有的__dict__,就可以找到通過(guò)對(duì)象summer可以調(diào)用和修改的所有屬性了。下面兩種屬性修改方法等效:

復(fù)制代碼 代碼如下:

summer.__dict__['age'] = 3
print(summer.__dict__['age'])

summer.age = 5
print(summer.age)

 (上面的情況中,我們已經(jīng)知道了summer對(duì)象的類(lèi)為chicken,而chicken類(lèi)的父類(lèi)為bird。如果只有一個(gè)對(duì)象,而不知道它的類(lèi)以及其他信息的時(shí)候,我們可以利用__class__屬性找到對(duì)象的類(lèi),然后調(diào)用類(lèi)的__base__屬性來(lái)查詢(xún)父類(lèi))

特性

同一個(gè)對(duì)象的不同屬性之間可能存在依賴(lài)關(guān)系。當(dāng)某個(gè)屬性被修改時(shí),我們希望依賴(lài)于該屬性的其他屬性也同時(shí)變化。這時(shí),我們不能通過(guò)__dict__的方式來(lái)靜態(tài)的儲(chǔ)存屬性。Python提供了多種即時(shí)生成屬性的方法。其中一種稱(chēng)為特性(property)。特性是特殊的屬性。比如我們?yōu)閏hicken類(lèi)增加一個(gè)特性adult。當(dāng)對(duì)象的age超過(guò)1時(shí),adult為T(mén)rue;否則為False:

復(fù)制代碼 代碼如下:

class bird(object):
    feather = True

class chicken(bird):
    fly = False
    def __init__(self, age):
        self.age = age
    def getAdult(self):
        if self.age > 1.0: return True
        else: return False
    adult = property(getAdult)   # property is built-in

summer = chicken(2)

print(summer.adult)
summer.age = 0.5
print(summer.adult)


特性使用內(nèi)置函數(shù)property()來(lái)創(chuàng)建。property()最多可以加載四個(gè)參數(shù)。前三個(gè)參數(shù)為函數(shù),分別用于處理查詢(xún)特性、修改特性、刪除特性。最后一個(gè)參數(shù)為特性的文檔,可以為一個(gè)字符串,起說(shuō)明作用。

我們使用下面一個(gè)例子進(jìn)一步說(shuō)明:

復(fù)制代碼 代碼如下:

class num(object):
    def __init__(self, value):
        self.value = value
    def getNeg(self):
        return -self.value
    def setNeg(self, value):
        self.value = -value
    def delNeg(self):
        print("value also deleted")
        del self.value
    neg = property(getNeg, setNeg, delNeg, "I'm negative")

x = num(1.1)
print(x.neg)
x.neg = -22
print(x.value)
print(num.neg.__doc__)
del x.neg

上面的num為一個(gè)數(shù)字,而neg為一個(gè)特性,用來(lái)表示數(shù)字的負(fù)數(shù)。當(dāng)一個(gè)數(shù)字確定的時(shí)候,它的負(fù)數(shù)總是確定的;而當(dāng)我們修改一個(gè)數(shù)的負(fù)數(shù)時(shí),它本身的值也應(yīng)該變化。這兩點(diǎn)由getNeg和setNeg來(lái)實(shí)現(xiàn)。而delNeg表示的是,如果刪除特性neg,那么應(yīng)該執(zhí)行的操作是刪除屬性value。property()的最后一個(gè)參數(shù)("I'm negative")為特性negative的說(shuō)明文檔。

使用特殊方法__getattr__

我們可以用__getattr__(self, name)來(lái)查詢(xún)即時(shí)生成的屬性。當(dāng)我們查詢(xún)一個(gè)屬性時(shí),如果通過(guò)__dict__方法無(wú)法找到該屬性,那么Python會(huì)調(diào)用對(duì)象的__getattr__方法,來(lái)即時(shí)生成該屬性。比如:

復(fù)制代碼 代碼如下:

class bird(object):
    feather = True

class chicken(bird):
    fly = False
    def __init__(self, age):
        self.age = age
    def __getattr__(self, name):
        if name == 'adult':
            if self.age > 1.0: return True
            else: return False
        else: raise AttributeError(name)

summer = chicken(2)

print(summer.adult)
summer.age = 0.5
print(summer.adult)

print(summer.male)

每個(gè)特性需要有自己的處理函數(shù),而__getattr__可以將所有的即時(shí)生成屬性放在同一個(gè)函數(shù)中處理。__getattr__可以根據(jù)函數(shù)名區(qū)別處理不同的屬性。比如上面我們查詢(xún)屬性名male的時(shí)候,raise AttributeError。

(Python中還有一個(gè)__getattribute__特殊方法,用于查詢(xún)?nèi)我鈱傩?。__getattr__只能用來(lái)查詢(xún)不在__dict__系統(tǒng)中的屬性)

__setattr__(self, name, value)和__delattr__(self, name)可用于修改和刪除屬性。它們的應(yīng)用面更廣,可用于任意屬性。

即時(shí)生成屬性的其他方式

即時(shí)生成屬性還可以使用其他的方式,比如descriptor(descriptor類(lèi)實(shí)際上是property()函數(shù)的底層,property()實(shí)際上創(chuàng)建了一個(gè)該類(lèi)的對(duì)象)。有興趣可以進(jìn)一步查閱。

總結(jié)

__dict__分層存儲(chǔ)屬性。每一層的__dict__只存儲(chǔ)該層新增的屬性。子類(lèi)不需要重復(fù)存儲(chǔ)父類(lèi)中的屬性。

即時(shí)生成屬性是值得了解的概念。在Python開(kāi)發(fā)中,你有可能使用這種方法來(lái)更合理的管理對(duì)象的屬性。

相關(guān)文章

  • 關(guān)于Python 常用獲取元素 Driver 總結(jié)

    關(guān)于Python 常用獲取元素 Driver 總結(jié)

    今天小編就為大家分享一篇關(guān)于Python 常用獲取元素 Driver 總結(jié),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-11-11
  • python實(shí)現(xiàn)五子棋小游戲

    python實(shí)現(xiàn)五子棋小游戲

    這篇文章主要介紹了python實(shí)現(xiàn)五子棋小游戲,使用pygame模塊編寫(xiě)一個(gè)五子棋游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-01-01
  • Python實(shí)現(xiàn)獲取網(wǎng)站PR及百度權(quán)重

    Python實(shí)現(xiàn)獲取網(wǎng)站PR及百度權(quán)重

    這篇文章主要介紹了Python實(shí)現(xiàn)獲取網(wǎng)站PR及百度權(quán)重,本文使用傳參的方式請(qǐng)求站長(zhǎng)工具和谷歌工具獲取PR值和百度權(quán)重,需要的朋友可以參考下
    2015-01-01
  • tensor.squeeze函數(shù)和tensor.unsqueeze函數(shù)的使用詳解

    tensor.squeeze函數(shù)和tensor.unsqueeze函數(shù)的使用詳解

    本文主要介紹了tensor.squeeze函數(shù)和tensor.unsqueeze函數(shù)的使用詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-03-03
  • python爬蟲(chóng)urllib中的異常模塊處理

    python爬蟲(chóng)urllib中的異常模塊處理

    這篇文章主要為大家介紹了python爬蟲(chóng)在爬取網(wǎng)頁(yè)時(shí)urllib中的異常模塊處理,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-05-05
  • python不使用for計(jì)算兩組、多個(gè)矩形兩兩間的iou方式

    python不使用for計(jì)算兩組、多個(gè)矩形兩兩間的iou方式

    今天小編就為大家分享一篇python不使用for計(jì)算兩組、多個(gè)矩形兩兩間的iou方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-01-01
  • 用Python調(diào)用win命令行提高工作效率的實(shí)例

    用Python調(diào)用win命令行提高工作效率的實(shí)例

    今天小編就為大家分享一篇用Python調(diào)用win命令行提高工作效率的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-08-08
  • 使用Python快速實(shí)現(xiàn)文件共享并通過(guò)內(nèi)網(wǎng)穿透技術(shù)公網(wǎng)訪(fǎng)問(wèn)

    使用Python快速實(shí)現(xiàn)文件共享并通過(guò)內(nèi)網(wǎng)穿透技術(shù)公網(wǎng)訪(fǎng)問(wèn)

    數(shù)據(jù)共享作為和連接作為互聯(lián)網(wǎng)的基礎(chǔ)應(yīng)用,不僅在商業(yè)和辦公場(chǎng)景有廣泛的應(yīng)用,對(duì)于個(gè)人用戶(hù)也有很強(qiáng)的實(shí)用意義,今天,筆者就為大家介紹,如何使用python這樣的簡(jiǎn)單程序語(yǔ)言,在自己的電腦上搭建一個(gè)共享文件服務(wù)器,需要的朋友可以參考下
    2023-10-10
  • Python安裝OpenCV的示例代碼

    Python安裝OpenCV的示例代碼

    這篇文章主要介紹了Python安裝OpenCV的示例代碼,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-03-03
  • django使用admin站點(diǎn)上傳圖片的實(shí)例

    django使用admin站點(diǎn)上傳圖片的實(shí)例

    今天小編就為大家分享一篇django使用admin站點(diǎn)上傳圖片的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-07-07

最新評(píng)論