使用@property
.
- 描述
@property(装饰器)将一个方法变成属性调用
- 场景
在绑定属性时,把属性暴露出去,写起来简单,但是没办法检查参数,导致可以把成绩随便改,为了限制score的范围,可以通过一个set_score()方法来设置成绩,再通过一个get_score()来获取成绩(检查参数)
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 be between 0 ~ 100!')
self._score = value
s = Student()
s.set_score(60)
print(s.get_score())
# 输出结果:60
s.set_score(101)
# 输出结果:ValueError:score must be between 0 ~ 100!
这种方法相对来说,略显复杂。装饰器可以给函数动态加上功能,可以用Python内置的@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
s = Student()
s.score = 60 # 实际转换为s.set_score(60)
print(s.score)
# 输出结果:60
s.score = 101
# 输出结果:ValueError:score must between 0 ~ 100!
@property
的实现比较复杂,把一个getter方法变成属性,只需要加上@property
就可以。此时,@property
本身又创建了另一个装饰器@score.setter
,负责把一个setter方法变成属性赋值
如果不定义setter方法,就会实现只读属性
class Stduent(object):
@property
def birth(self):
return self._birth
@birth.setter
def birth(self, value):
self._birth = value
@property
def age(self):
return 2019 - self._birth
birth
是可读写属性,而age
是只读属性