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'

  

 

posted @ 2019-04-03 18:00  skyfly0772  阅读(125)  评论(0编辑  收藏  举报