目錄
什么是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內置得 @propert
y 裝飾器就是負責把一個方法變成屬性調用得
# -*- 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裝飾器內容請搜索之家以前得內容或繼續瀏覽下面得相關內容希望大家以后多多支持之家!