python中hasattr()、getattr()、setattr()函式的使用
引言:
在閱讀高手寫的程式碼時,有很多簡寫的形式,如果沒有見過還真的看不太懂是什麼意思,其中一個比較常用的就是getattr()用來呼叫一個類中的變數或者方法,相關聯的hasattr()、getattr()、setattr()函式的使用也一併學習了一下;
正文:
1. hasattr(object, name)
判斷object物件中是否存在name屬性,當然對於python的物件而言,屬性包含變數和方法;有則返回True,沒有則返回False;需要注意的是name引數是string型別,所以不管是要判斷變數還是方法,其名稱都以字串形式傳參;getattr和setattr也同樣;
>>> >>> class A(): name = 'python' def func(self): return 'A()類的方法func()' >>> >>> hasattr(A, 'name') True >>> >>> hasattr(A, 'age') False >>> >>> hasattr(A, 'func') True >>>
2. getattr(object, name[, default])
獲取object物件的屬性的值,如果存在則返回屬性值,如果不存在分為兩種情況,一種是沒有default引數時,會直接報錯;給定了default引數,若物件本身沒有name屬性,則會返回給定的default值;如果給定的屬性name是物件的方法,則返回的是函式物件,需要呼叫函式物件來獲得函式的返回值;呼叫的話就是函式物件後面加括號,如func之於func();
另外還需要注意,如果給定的方法func()是例項函式,則不能寫getattr(A, 'func')(),因為fun()是例項函式的話,是不能用A類物件來呼叫的,應該寫成getattr(A(), 'func')();例項函式和類函式的區別可以簡單的理解一下,例項函式定義時,直接def func(self):,這樣定義的函式只能是將類例項化後,用類的例項化物件來呼叫;而類函式定義時,需要用@classmethod來裝飾,函式預設的引數一般是cls,類函式可以通過類物件來直接呼叫,而不需要對類進行例項化;
>>>
>>> class A():
name = 'python'
def func(self):
return 'Hello world'
>>>
>>> getattr(A, 'name')
'python'
>>>
>>> getattr(A, 'age') # age變數不存在則報錯
Traceback (most recent call last):
File "<pyshell#464>", line 1, in <module>
getattr(A, 'age')
AttributeError: class A has no attribute 'age'
>>>
>>> getattr(A, 'age', 20)
20
>>>
>>> getattr(A, 'func')
<unbound method A.func>
>>>
>>> getattr(A, 'func')() # func()函式不能被A類物件呼叫,所以報錯
Traceback (most recent call last):
File "<pyshell#470>", line 1, in <module>
getattr(A, 'func')()
TypeError: unbound method func() must be called with A instance as first argument (got nothing instead)
>>>
>>> getattr(A(), 'func')()
'Hello world'
>>>
>>> class A(object):
name = 'python'
@classmethod
def func(cls):
return 'the method of A object.'
>>>
>>> getattr(A, 'func')()
'the method of A object.'
>>>
3. setattr(object, name, value)
給object物件的name屬性賦值value,如果物件原本存在給定的屬性name,則setattr會更改屬性的值為給定的value;如果物件原本不存在屬性name,setattr會在物件中建立屬性,並賦值為給定的value;
>>> >>> class A(): name = 'python' def func(self): return 'Hello world' >>> >>> setattr(A, 'name', 'java') >>> getattr(A, 'name') 'java' >>> >>> setattr(A, 'age', 20) >>> getattr(A, 'age') 20 >>>
一般先判斷物件中是否存在某屬性,如果存在則返回;如果不存在,則給物件增加屬性並賦值;很簡單的if-else判斷:
>>> >>> class A(): name = 'python' def func(self): return 'Hello world' >>> >>> if hasattr(A, 'age'): print getattr(A, 'age') else: setattr(A, 'age', 20) >>> >>> getattr(A, 'age') 20 >>>