在綁定屬性時(shí)熊咽,如果我們直接把屬性暴露出去砰苍,雖然寫起來很簡單潦匈,但是阱高,沒辦法檢查參數(shù),導(dǎo)致可以把成績隨便改:
s = Student()
s.score = 9999
這顯然不合邏輯茬缩。為了限制 score
的范圍赤惊,可以通過一個(gè) set_score()
方法來設(shè)置成績,再通過一個(gè) get_score()
來獲取成績凰锡,這樣未舟,在 set_score()
方法里,就可以檢查參數(shù):
class Student(object):
def get_score(self):
return self._score
def set_score(self, value):
# 參數(shù)類型必須是整型
if not isinstance(value, int):
raise ValueError('score must be an integer!')
# 參數(shù)類型必須是整型
if value < 0 or value > 100:
raise ValueError('score must between 0 ~ 100!')
self._score = value
但是掂为,上面的調(diào)用方法又略顯復(fù)雜裕膀,沒有直接用屬性這么直接簡單。
有沒有既能檢查參數(shù)勇哗,又可以用類似屬性這樣簡單的方式來訪問類的變量呢昼扛?Python 內(nèi)置的 @property
裝飾器就是負(fù)責(zé)把一個(gè)方法變成屬性調(diào)用的:
class Student(object):
# __slots__ = ('name', 'score')
def __init__(self, name, score):
self.name = name
self.score = score
@property
def score(self):
return self._score
@score.setter
def score(self, value):
# 參數(shù)類型必須是整型
if not isinstance(value, int):
raise ValueError('score must be an integer!')
# 參數(shù)范圍
if value < 0 or value > 100:
raise ValueError('score must between 0 ~ 100!')
self._score = value
測試一下:
>>> bart = Student('bart', 60)
>>> bart.score
60
>>> bart.score = 1000
......
ValueError: score must between 0 ~ 100!
加上 @property
可以把一個(gè) getter
方法變成屬性,而 @property
本身又創(chuàng)建了另一個(gè)裝飾器 @score.setter
智绸,負(fù)責(zé)把一個(gè) setter
方法變成屬性賦值野揪。