1. 程式人生 > >python中hasattr()、getattr()、setattr()函式的使用

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
>>>