1.property 裝飾器:裝飾器是在不修改被裝飾對象源代碼以及調用方式的前提下為被裝飾對象添加新功能的可調用對象 property是一個裝飾器,是用來綁定給對象的方法偽造成一個數據屬性 裝飾器property,可以將類中的函數“偽裝成”對象的數據屬性,對象在訪問該特殊屬性時會觸發功能的執行,然後 ...
1.property
裝飾器:裝飾器是在不修改被裝飾對象源代碼以及調用方式的前提下為被裝飾對象添加新功能的可調用對象
property是一個裝飾器,是用來綁定給對象的方法偽造成一個數據屬性
裝飾器property,可以將類中的函數“偽裝成”對象的數據屬性,對象在訪問該特殊屬性時會觸發功能的執行,然後將返回值作為本次訪問的結果。
使用property有效地保證了屬性訪問的一致性。另外property還提供設置和刪除屬性的功能
應用場景:有的功能屬性聽起來更像數據屬性,python則提供了一種裝飾器,可以將功能屬性偽裝成數據屬性
2.案例:
"""
成人的BMI數值:
過輕:低於18.5
正常:18.5-23.9
過重:24-27
肥胖:28-32
非常肥胖, 高於32
體質指數(BMI)=體重(kg)÷身高^2(m)
EX:70kg÷(1.75×1.75)=22.86
"""
案例一:
class People:
def __init__(self, name, weight, height):
self.name = name
self.weight = weight
self.height = height
# 定義函數的原因1:
# 1、從bmi的公式上看,bmi應該是觸發功能計算得到的
# 2、bmi是隨著身高、體重的變化而動態變化的,不是一個固定的值
# 說白了,每次都是需要臨時計算得到的
# 但是bmi聽起來更像是一個數據屬性,而非功能
@property
def bmi(self):
return self.weight / (self.height ** 2)
obj1 = People('egon', 70, 1.83)
print(obj1.bmi())
obj1.height=1.86
print(obj1.bmi())
print(obj1.bmi)
案例二:
'''
學習中遇到問題沒人解答?小編創建了一個Python學習交流群:711312441
尋找有志同道合的小伙伴,互幫互助,群里還有不錯的視頻學習教程和PDF電子書!
'''
class People:
def __init__(self, name):
self.__name = name
def get_name(self):
return self.__name
def set_name(self, val):
if type(val) is not str:
print('必須傳入str類型')
return
self.__name = val
def del_name(self):
print('不讓刪除')
# del self.__name
name=property(get_name,set_name,del_name)
obj1=People('egon')
# print(obj1.get_name())
# obj1.set_name('EGON')
# print(obj1.get_name())
# obj1.del_name()
# 人正常的思維邏輯
print(obj1.name) #
# obj1.name=18
# del obj1.name
案例三:
class People:
def __init__(self, name):
self.__name = name
@property
def name(self): # obj1.name
return self.__name
@name.setter
def name(self, val): # obj1.name='EGON'
if type(val) is not str:
print('必須傳入str類型')
return
self.__name = val
@name.deleter
def name(self): # del obj1.name
print('不讓刪除')
# del self.__name
obj1=People('egon')
# 人正常的思維邏輯
print(obj1.name) #
# obj1.name=18
# del obj1.name