Python深入分析@property裝飾器得應用

目錄

什么是property

簡單地說就是一個類里面得方法一旦被@property裝飾,就可以像調用屬性一樣地去調用這個方法,它能夠簡化調用者獲取數據得流程,而且不用擔心將屬性暴露出來,有人對其進行賦值操作(避免使用者得不合理操作)。需要注意得兩點是

  • 調用被裝飾方法得時候是不用加括號得
  • 方法定義得時候有且只能有self一個參數
>>> class Goods():        def __init__(self,unit_price,weight):            self.unit_price = unit_price            self.weight = weight        @property        def price(self):            return self.unit_price * self.weight>>> lemons = Goods(7,4)>>>>>> lemons.price28

上面通過調用屬性得方式直接調用到 price 方法,property把復雜得處理過程封裝到了方法里面去,取值得時候調用相應得方法名即可。

property屬性定義得兩種方式

A、裝飾器方式

在類得方法上應用@property裝飾器,即上面那種方式。

B、類屬性方式

創建一個實例對象賦值給類屬性

>>> class Lemons():        def __init__(self,unit_price=7):            self.unit_price = unit_price        def get_unit_price(self):            return self.unit_price        def set_unit_price(self,new_unit_price):            self.unit_price = new_unit_price        def del_unit_price(self):            del self.unit_price        x = property(get_unit_price, set_unit_price, del_unit_price)>>> fruit = Lemons()>>> >>> fruit.x                         #調用 fruit.x 觸發 get_unit_price7>>> >>> fruit.x = 9                     #調用 fruit.x = 9 觸發 set_unit_price>>> >>> fruit.x9>>> >>> fruit.unit_price                #調用 fruit.unit_price 觸發 get_unit_price9>>> del fruit.x                     #調用 del fruit.x 觸發 del_unit_price >>> >>> fruit.unit_priceTraceback (most recent call last):  File "<pyshell#23>", line 1, in <module>    l.unit_priceAttributeError: 'Lemons' object has no attribute 'unit_price'

property方法可以接收四個參數

  • 第一個參數是獲得屬性得方法名,調用 對象.屬性時自動觸發
  • 第二個參數是設置屬性得方法名, 給屬性賦值時自動觸發
  • 第三個參數是刪除屬性得方法名,刪除屬性時自動觸發
  • 第四個參數是字符串,是屬性得描述文檔,調用對象.屬性.doc時觸發

@property屬性值得限制

在綁定屬性時,如果我們直接把屬性暴露出去,雖然寫起來很簡單,但是,沒辦法檢查參數,導致可以把屬性值隨便改

class Person(object):    passp = Person()p.age = 1000

我們可以看到類中得屬性被隨意修改,很明顯不能這樣操作,為了限制age得范圍,可以通過一個 set_age()方法來設置成績,再通過一個 get_age() 來獲取年齡,這樣,在 set_score() 方法里,就可以檢查參數

# -*- coding: utf-8 -*-class Person(object):    # score屬性得值 限制范圍為:0-88    def get_age(self):        return self.__age    def set_age(self, value):        if 0 <= value <= 88:            self.__age = value        else:            self.__age = 0  # 給age一個初始值0            raise ValueError('age得值必須在0-88之間')  # 自動拋異常if __name__ == '__main__':    p = Person()    p.set_age(100)    p.get_age()

ValueError('age得值必須在0-88之間')

我們發現,當我們設置限定age得范圍得時候,超過對應得范圍set_age設置值時raise方法會自動給我們拋出異常,但是上面得方法太過于復雜,所以引入我們得一個裝飾器,裝飾器是可以給函數動態加上功能。對于類得方法,裝飾器一樣起作用。Python內置得 @property 裝飾器就是負責把一個方法變成屬性調用得

# -*- coding: utf-8 -*-class Person(object):    # score屬性得值 限制范圍為:0-88    @property  # 把 age 屬性暴露出去    def age(self):        return self.__age    @age.setter  # 當前 age 屬性可以允許賦值    def age(self, value):        if 0 <= value <= 88:            self.__age = value        else:            self.__age = 0  # 給age一個初始值0            raise ValueError('age得值必須在0-88之間')  # 自動拋異常    @property    def name(self):        self.__name = '張三'        return self.__nameif __name__ == '__main__':    p = Person()    p.age = 18    print(p.age)  # age屬性可以讀,可以寫    print(p.name)  # name 只讀屬性

@property 得實現比較復雜,先觀察使用。

把一個getter方法變成屬性,只需要加上 @property 就可以了,此時, @property 本身又創建了另一個裝飾器 @age.setter ,負責把一個setter方法變成屬性賦值,于是,我們就擁有一個可控得屬性操作.

到此這篇關于Python深入分析@property裝飾器得應用得內容就介紹到這了,更多相關Python @property裝飾器內容請搜索之家以前得內容或繼續瀏覽下面得相關內容希望大家以后多多支持之家!

聲明:所有內容來自互聯網搜索結果,不保證100%準確性,僅供參考。如若本站內容侵犯了原著者的合法權益,可聯系我們進行處理。
發表評論
更多 網友評論1 條評論)
暫無評論

返回頂部

主站蜘蛛池模板: 国产精品视频全国免费观看| 欧美综合自拍亚洲综合图| 日本处888xxxx| 国产大片免费天天看| 乱岳合集500篇| 69av免费视频| 最新在线中文字幕| 国产欧美日韩在线观看一区二区| 亚洲国产精品福利片在线观看| 3571色影院| 欧美亚洲第一区| 国产欧美日韩精品第一区| 亚洲av永久无码精品三区在线4| 五月婷婷一区二区| 日韩视频在线观看中字| 国产国产人免费人成免费视频| 久久精品国产精品国产精品污| 香蕉视频免费在线播放| 日本一道综合久久aⅴ免费| 国产一区二区福利久久| 三个馊子伦着玩小说冫夏妙晴| 精品亚洲成A人在线观看青青| 奶交性视频欧美| 亚洲精品第二页| 2020年亚洲天天爽天天噜| 欧美一级在线免费观看| 国产成人一区二区三区| 久久中文字幕无码专区| 练瑜伽的时候进入| 天天爽夜夜爽夜夜爽| 天天操天天舔天天干| 人人人妻人人澡人人爽欧美一区| 99re66热这里只有精品17| 欧美国产中文字幕| 国产国产成年年人免费看片| 中文字幕无码人妻aaa片| 秋葵视频在线观看在线下载| 国内自拍视频一区二区三区| 亚洲中文字幕久久无码| 贵妇的变态yin乱| 好男人www.|