這期內(nèi)容當(dāng)中小編將會(huì)給大家?guī)?lái)有關(guān)python中@property 屬性的作用是什么,文章內(nèi)容豐富且以專(zhuān)業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。
創(chuàng)新互聯(lián)于2013年成立,是專(zhuān)業(yè)互聯(lián)網(wǎng)技術(shù)服務(wù)公司,擁有項(xiàng)目網(wǎng)站制作、成都做網(wǎng)站網(wǎng)站策劃,項(xiàng)目實(shí)施與項(xiàng)目整合能力。我們以讓每一個(gè)夢(mèng)想脫穎而出為使命,1280元市中做網(wǎng)站,已為上家服務(wù),為市中各地企業(yè)和個(gè)人服務(wù),聯(lián)系電話(huà):18982081108
在綁定屬性時(shí),如果我們直接把屬性暴露出去,雖然寫(xiě)起來(lái)很簡(jiǎn)單,但是,沒(méi)辦法檢查參數(shù),導(dǎo)致可以把成績(jī)隨便改:
s = Student() s.score = 9999
這顯然不合邏輯。為了限制score的范圍,可以通過(guò)一個(gè)set_score()
方法來(lái)設(shè)置成績(jī),再通過(guò)一個(gè)get_score()
來(lái)獲取成績(jī),這樣,在set_score()
方法里,就可以檢查參數(shù):
class Student(object):def get_score(self):return self._scoredef 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
現(xiàn)在,對(duì)任意的Student實(shí)例進(jìn)行操作,就不能隨心所欲地設(shè)置score了:
>>> s = Student()>>> s.set_score(60) # ok!>>> s.get_score()60>>> s.set_score(9999) Traceback (most recent call last): ... ValueError: score must between 0 ~ 100!
但是,上面的調(diào)用方法又略顯復(fù)雜,沒(méi)有直接用屬性這么直接簡(jiǎn)單。
有沒(méi)有既能檢查參數(shù),又可以用類(lèi)似屬性這樣簡(jiǎn)單的方式來(lái)訪(fǎng)問(wèn)類(lèi)的變量呢?對(duì)于追求完美的Python程序員來(lái)說(shuō),這是必須要做到的!
還記得裝飾器(decorator)可以給函數(shù)動(dòng)態(tài)加上功能嗎?對(duì)于類(lèi)的方法,裝飾器一樣起作用。Python內(nèi)置的@property
裝飾器就是負(fù)責(zé)把一個(gè)方法變成屬性調(diào)用的:
class Student(object): @propertydef score(self):return self._score@score.setterdef 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
的實(shí)現(xiàn)比較復(fù)雜,我們先考察如何使用。把一個(gè)getter方法變成屬性,只需要加上@property
就可以了,此時(shí),@property
本身又創(chuàng)建了另一個(gè)裝飾器@score.setter
,負(fù)責(zé)把一個(gè)setter方法變成屬性賦值,于是,我們就擁有一個(gè)可控的屬性操作:
>>> s = Student()>>> s.score = 60 # OK,實(shí)際轉(zhuǎn)化為s.set_score(60)>>> s.score # OK,實(shí)際轉(zhuǎn)化為s.get_score()60>>> s.score = 9999Traceback (most recent call last): ... ValueError: score must between 0 ~ 100!
注意到這個(gè)神奇的@property
,我們?cè)趯?duì)實(shí)例屬性操作的時(shí)候,就知道該屬性很可能不是直接暴露的,而是通過(guò)getter和setter方法來(lái)實(shí)現(xiàn)的。
還可以定義只讀屬性,只定義getter方法,不定義setter方法就是一個(gè)只讀屬性:
class Student(object):@propertydef birth(self):return self._birth@birth.setterdef birth(self, value):self._birth = value@propertydef age(self):return 2014 - self._birth
上面的birth
是可讀寫(xiě)屬性,而age
就是一個(gè)只讀屬性,因?yàn)?code>age可以根據(jù)birth
和當(dāng)前時(shí)間計(jì)算出來(lái)。
上述就是小編為大家分享的python中@property 屬性的作用是什么了,如果剛好有類(lèi)似的疑惑,不妨參照上述分析進(jìn)行理解。如果想知道更多相關(guān)知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。