欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時間:2022年07月21日 10:45:06   作者:Flyme awei  
這篇文章主要介紹了Python @property裝飾器的用法,在Python中,可以通過@property裝飾器將一個方法轉換為屬性,從而實現(xiàn)用于計算的屬性,下面文章圍繞主題展開更多相關詳情,感興趣的小伙伴可以參考一下

什么是property

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

  • 調用被裝飾方法的時候是不用加括號的
  • 方法定義的時候有且只能有self一個參數(shù)
>>> 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.price
28

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

property屬性定義的兩種方式

A、裝飾器方式

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

B、類屬性方式

創(chuàng)建一個實例對象賦值給類屬性

>>> 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 觸發(fā) get_unit_price
7
>>> 
>>> fruit.x = 9                     #調用 fruit.x = 9 觸發(fā) set_unit_price
>>> 
>>> fruit.x
9
>>> 
>>> fruit.unit_price                #調用 fruit.unit_price 觸發(fā) get_unit_price
9
>>> del fruit.x                     #調用 del fruit.x 觸發(fā) del_unit_price 
>>> 
>>> fruit.unit_price
Traceback (most recent call last):
  File "<pyshell#23>", line 1, in <module>
    l.unit_price
AttributeError: 'Lemons' object has no attribute 'unit_price'

property方法可以接收四個參數(shù)

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

@property屬性值的限制

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

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

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

# -*- 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之間')

我們發(fā)現(xiàn),當我們設置限定age的范圍的時候,超過對應的范圍set_age設置值時raise方法會自動給我們拋出異常,但是上面的方法太過于復雜,所以引入我們的一個裝飾器,裝飾器是可以給函數(shù)動態(tài)加上功能。對于類的方法,裝飾器一樣起作用。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.__name
if __name__ == '__main__':
    p = Person()
    p.age = 18
    print(p.age)  # age屬性可以讀,可以寫
    print(p.name)  # name 只讀屬性

@property 的實現(xiàn)比較復雜,先觀察使用。

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

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

相關文章

最新評論