1.@property实现只读变量
class Test():
def __init__(self, val):
self.__val= val
@property
def onlyReadVal(self):
return self.__val - 1
f = Test(2)
print(f.onlyReadVal)
运行结果:2
如果添加:
f.onlyReadVal = 3
会报错:
AttributeError: can't set attribute
因为 onlyReadVal
不是普通的属性(定义在init
里边),也不是方法,无法进行修改。
2.拓展:@property含义
首先,在绑定属性时,如果我们直接把属性暴露出去,虽然写起来很简单,但是,没办法检查参数。
因此,这时不能直接用属性,而是用方法来实现:
class Student(object):
def get_score(self):
return self._score
def set_score(self, value):
if not isinstance(value, int):
raise ValueError('score must be an integer!')
if value < 0 or value > 100:
raise ValueError('score must between 0 ~ 100!')
self._score = value
但是,使用@property
就能使用属性,并且能检查参数。
class Student(object):
@property
def score(self):
return self._score
@score.setter
def score(self, value):
if not isinstance(value, int):
raise ValueError('score must be an integer!')
if value < 0 or value > 100:
raise ValueError('score must between 0 ~ 100!')
self._score = value
因此,对@property
只定义getter方法,不定义setter方法就是一个只读属性.
class Student(object):
@property
def birth(self):
return self._birth
@birth.setter
def birth(self, value):
self._birth = value
@property
def age(self):
return 2014 - self._birth
上面的birth
是可读写属性,而age
就是一个只读属性,因为age
可以根据birth
和当前时间计算出来。
参考: