在类的方法上加上一行@property 装饰器,会使得用户调用该函数属性时,就像调用数据属性一样,不需要加上()
比如想获取一些名词,再加上括号,容易使调用者忘记。动词才加()调用方法.
如下示例:
‘‘‘
BMI指数(bmi是计算而来的,但很明显它听起来像是一个属性而非方法,如果我们将其做成一个属性,更便于理解)
成人的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 @property def bmi(self): return self.weight / (self.height ** 2) p=People(‘egon‘,75,1.81) # p.bmi=p.weight / (p.height ** 2) # print(p.bmi) #使用数据属性不需要加() # # print(p.bmi()) #没加@property装饰器时,调用p.bmi()是需要加括号的 # print(p.bmi) #加上@property装饰器后,调用p.bmi()可以不加括号。 # p.height=1.82 # print(p.bmi) #p.bmi值会随着height的变化而变化。 p.bmi=3333 #报错AttributeError: can‘t set attribute
以下是需要了解的内容:
要怎么才能修改被@property装饰的属性呢?
@name.setter @name.deleter name是被@property修饰过的方法名
设置name时触发setter
删除name时触发deleter
getname时@property
class People: def __init__(self,name): self.__name=name @property def name(self): # print(‘getter‘) #p.name时触发该方法 return self.__name @name.setter def name(self,val): #p.name = ‘EGON‘ 时触发该方法 # print(‘setter‘,val) if not isinstance(val,str): print(‘名字必须是字符串类型‘) return self.__name=val @name.deleter def name(self): # del p.name时触发该方法 print(‘deleter‘) print(‘不允许删除‘) p=People(‘egon‘) # print(p.get_name()) # print(p.name) # p.name # p.name=‘EGON‘ # p.name=123 # print(p.name) del p.name
原文:https://www.cnblogs.com/beallaliu/p/9114159.html