Python 中@property的用法詳解
在綁定屬性時,如果我們直接把屬性賦值給對象,比如:
p = Person() p.name= 'Mary'
我們先看個詳細的例子(注意雙下劃線name和age定義為私有變量):
class Person(object):
def __init__(self, name, age):
self.__name = name
self.__age = age
def get_age_fun(self):
return self.__age
def set_age_fun(self, value):
if not isinstance(value, int):
raise ValueError('年齡必須是數(shù)字!')
if value < 0 or value > 100:
raise ValueError('年齡必須是0-100')
self.__age = value
def print_info(self):
print('%s: %s' % (self.__name, self.__age))
p = Person('balala',20)
p.__age = 17
print(p.__age) # 17
print(p.get_age_fun()) # 20 表面上看,上面代碼“成功”地設置了__age變量 17,但實際上這個__age變量和class內(nèi)部的__age變量不是一個變量!
# 內(nèi)部的__age變量已經(jīng)被Python解釋器自動改成了_Person_age,而外部代碼給p新增了一個__age變量。 所以調用 get_age_fun輸出的是初始值
p.set_age_fun(35)
print(p.get_age_fun()) # 35
print(p.print_info()) # balala: 35
輸出:
17
20
35
balala: 35
表面上看,外部代碼“成功”地設置了__age變量 17,但實際上這個_age變量和class內(nèi)部的_age變量不是一個變量!
內(nèi)部的_age變量已經(jīng)被Python解釋器自動改成了_Person_age,而外部代碼給p新增了一個_age變量。 所以調用 get_age_fun輸出的是初始值 20
而set_age_fun 通過class內(nèi)部改變了age變量值,所以最終輸出 balala: 35
我們再稍微調整下:
(注意只改變了一個變量名: 原來的私有屬性 __age 單下劃線為: _age,也可以定義為:age.
解釋:以一個下劃線開頭的實例變量名,比如_age,這樣的實例變量外部是可以訪問的,但是,按照約定俗成的規(guī)定,當看到這樣的變量時,意思是,"雖然可以被訪問,但是,請視為私有變量,不要隨意訪問。")
class Person(object):
def __init__(self, name, age):
self.__name = name
self._age = age
def get_age_fun(self):
return self._age
def set_age_fun(self, value):
if not isinstance(value, int):
raise ValueError('年齡必須是數(shù)字!')
if value < 0 or value > 100:
raise ValueError('年齡必須是0-100')
self._age = value
def print_info(self):
print('%s: %s' % (self.__name, self._age))
p = Person('balala',20)
p._age = 17
print(p._age) # 17
print(p.get_age_fun()) # 這里是17 不再是 20,因為此時_age是全局變量,外部直接影響到類內(nèi)部的更新值
p.set_age_fun(35)
print(p.get_age_fun()) # 35
print(p.print_info()) # balala: 35
輸出:
1 17
2 17
3 35
4 balala: 35
看的出私有和全局的設置
但是,上面的調用方法是不是略顯復雜,沒有直接用屬性這么直接簡單。
有沒有可以用類似屬性這樣簡單的方式來訪問類的變量呢?必須的,對于類的方法
我們先來看一個稍微改造的例子:(稍后我們再使用Python內(nèi)置的@property裝飾器就是負責把一個方法變成屬性調用.)
我們進入正題:看看@property的妙用之處:
class Person(object):
def __init__(self, name, age):
self.__name = name
self.__age = age
@property
def get_age_fun(self):
return self.__age
@get_age_fun.setter # get_age_fun是上面聲明的方法
def set_age_fun(self, value):
if not isinstance(value, int):
raise ValueError('年齡必須是數(shù)字!')
if value < 0 or value > 100:
raise ValueError('年齡必須是0-100')
self.__age = value
def print_info(self):
print('%s: %s' % (self.__name, self.__age))
p = Person('balala',20)
p.__age = 17
print(p.__age) # 17
print(p.get_age_fun) # 20 注意這里不帶()
#p.set_age_fun(35) 注意不能這樣調用賦值了
p.set_age_fun = 35 # 這里set_age_fun 就是 聲明的函數(shù)不帶()
print(p.get_age_fun) # 35
print(p.print_info()) # balala: 35
輸出:
17
20
35
balala: 35
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
- python @property的用法及含義全面解析
- 介紹Python的@property裝飾器的用法
- 實例講解Python編程中@property裝飾器的用法
- python 中的@property的用法詳解
- Python @property裝飾器原理解析
- 詳解Python裝飾器之@property
- Python進階之@property動態(tài)屬性的實現(xiàn)
- python裝飾器中@property屬性的使用解析
- Python @property原理解析和用法實例
- Python如何使用@property @x.setter及@x.deleter
- Python @property使用方法解析
- python中@Property屬性使用方法
- python中@property注解的具體使用
相關文章
Windows系統(tǒng)Python直接調用C++ DLL的方法
這篇文章主要介紹了Windows系統(tǒng)Python直接調用C++ DLL文件的方法,本文給大家介紹的非常詳細,具有一定的參考借鑒價值 ,需要的朋友可以參考下2019-08-08
requests.post()方法中data和json參數(shù)的使用
這篇文章主要介紹了requests.post()方法中data和json參數(shù)的使用方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-02-02
python中從for循環(huán)延申到推導式的具體使用
這篇文章主要介紹了python中從for循環(huán)延申到推導式的具體使用,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-11-11
從基礎公式到動態(tài)函數(shù)生成詳解Python操作Excel的完整指南
數(shù)據(jù)分析師和業(yè)務人員在日常工作中,經(jīng)常需要處理大量的Excel數(shù)據(jù),本文將深入探討如何利用Python庫,特別是Spire.XLS for Python,高效地在Excel表格中插入各種函數(shù)和公式,從而實現(xiàn)數(shù)據(jù)處理的自動化,有需要的可以了解下2025-12-12
Python3中的re.findall()方法及re.compile()
這篇文章主要介紹了Python3中的re.findall()方法及re.compile(),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-05-05

