Python 特性 @property
什么是特性property
@property是一种特殊的属性,访问它时会执行一段功能(函数)然后返回值
@property
广泛应用在类的定义中,可以让调用者写出简短的代码,同时保证对参数进行必要的检查,这样,程序运行时就减少了出错的可能性。
将一个类的函数定义成特性以后,对象再去使用的时候obj.name,根本无法察觉自己的name是执行了一个函数然后计算出来的,这种不能随便赋值的特性的使用方式遵循了统一访问的原则。
import math class Circle: def __init__(self,radius): #圆的半径radius self.radius=radius @property def area(self): return math.pi * self.radius**2 #计算面积 @property def perimeter(self): return 2*math.pi*self.radius #计算周长 c=Circle(10) print(c.radius) print(c.area) #可以向访问数据属性一样去访问area,会触发一个函数的执行,动态计算出一个值 print(c.perimeter) #同上 ''' 输出结果: 314.1592653589793 62.83185307179586
c.area=3 此时的特性arear和perimeter不能被赋值,因为缺少setter的函数方 抛出异常 AttributeError: can't set attribute
'''
@property属性的修改和删除
class Foo: def __init__(self,val): self.__NAME=val #将所有的数据属性都隐藏起来 @property #首先使用@property装饰器和相关方法将属性name设置为可读 def name(self): return self.__NAME #obj.name访问的是self.__NAME(这也是真实值的存放位置) @name.setter #@name.setter装饰器将name属性上的 设置关联 def name(self,value): if not isinstance(value,str): #在设定值之前进行类型检查 raise TypeError('%s must be str' %value) #raise主动抛出异常终止程序 self.__NAME=value#通过类型检查后,将值value存放到真实的位置self.__NAME @name.deleter ##@name.deleter装饰器将name属性上的 删除关联 def name(self): #raise TypeError('Can not delete') del self.name #del self.__NAME f=Foo('egon') print(f.name) #输出egon f.name='ABCD' #无异常 print(f.name) #输出 ABCD #f.name=10 #抛出异常'TypeError: 10 must be str' #del f.name #抛出异常'TypeError: Can not delete' #print(f.name) #AttributeError: 'Foo' object has no attribute '_Foo__NAME'