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'
浙公网安备 33010602011771号