python class 的屬性

來源:互聯網
上載者:User

Class 有一些特殊的屬性,便於我們獲得一些額外的資訊。

 1 >>> class Class1(object): 2     """Class1 Doc.""" 3     def __init__(self): 4         self.i = 1234 5  6 >>> Class1.__doc__ # 類型協助資訊 7 'Class1 Doc.' 8 >>> Class1.__name__ # 類型名稱 9 'Class1'10 >>> Class1.__module__ # 類型所在模組11 '__main__'12 >>> Class1.__bases__ # 類型所繼承的基類13 (<type 'object'>,)14 >>> Class1.__dict__ # 類型字典,儲存所有類型成員資訊。15 <dictproxy object at 0x00D3AD70>16 >>> Class1().__class__ # 類型17 <class '__main__.Class1'>18 >>> Class1().__module__ # 執行個體類型所在模組19 '__main__'20 >>> Class1().__dict__ # 對象字典,儲存所有執行個體成員資訊。21 {'i': 1234}

 

成員

Python Class 同樣包含類型和執行個體兩種成員。

1 >>> class Class1:2     i = 123 # Class Field3     def __init__(self):4         self.i = 12345 # Instance Field5         6 >>> print Class1.i7 1238 >>> print Class1().i9 12345

 

兩個比較重要的取執行個體屬性的函數:

getattr(執行個體,屬性名稱),hasattr(執行個體,屬性名稱)判斷屬性名稱是否屬於執行個體。

如上例:s='i',getattr(Class1(),s)=12345

hasattr(Class1(),s)=True

-----------------------

有幾個很 "特殊" 的 "規則" 需要注意。

(1) 我們可以通過執行個體引用訪問類型成員。因此下面的例子中 self.i 實際指向 Class1.i,直到我們為執行個體新增了一個成員 i。

 1 >>> class Class1: 2     i = 123 3     def __init__(self): 4         print self.i  5         print hex(id(self.i)) 6  7 >>> hex(id(Class1.i)) # 顯示 Class1.i 8 '0xab57a0' 9 >>> a = Class1() # 建立 Class1 執行個體,我們會發現 self.i 實際指向 Class1.i。10 12311 0xab57a012 >>> Class1.__dict__ # 顯示 Class1 成員13 {'i': 123, '__module__': '__main__', '__doc__': None, '__init__': <function __init__ at 0x00D39470>}14 >>> a.__dict__ # 顯示執行個體成員15 {}16 >>> a.i = 123456789 # 為執行個體新增一個成員 i17 >>> hex(id(a.i)) # 顯示新增執行個體成員地址18 '0xbbb674'19 >>> a.__dict__ # 顯示執行個體成員20 {'i': 123456789}

 

我們可以在成員名稱前添加 "__" 使其成為私人成員。

1 >>> class Class1:2     __i = 1233     def __init__(self):4         self.__x = 05     def __test(self):6         print id(self)


事實上這隻是一種規則,並不是編譯器上的限制。我們依然可以用特殊的文法來訪問私人成員。
1 >>> Class1._Class1__i2 1233 >>> a = Class1()4 >>> a._Class1__x5 06 >>> a._Class1__test()7 13860376

 


-----------------------

除了靜態(類型)欄位,我們還可以定義靜態方法。
1 >>> class Class1:2     @staticmethod3     def test():4         print "static method"5 >>> Class1.test()6 static method

 

重載
Python 支援一些特殊方法和運算子多載。

 1 >>> class Class1: 2     def __init__(self): 3         self.i = 0 4     def __str__(self): 5         return "id=%i" % id(self) 6     def __add__(self, other): 7         return self.i + other.i 8  9 >>> a = Class1()10 >>> a.i = 1011 >>> str(a)12 'id=13876120'13 >>> b = Class1()14 >>> b.i = 2015 >>> a + b16 30

通過重載 "__eq__",我們可以改變 "==" 運算子的行為。
 1 >>> class Class1: 2     pass 3  4 >>> a = Class1() 5 >>> b = Class1() 6 >>> a == b 7 False 8  9 >>> class Class1:10     def __eq__(self, x):11         return 5512 >>> a = Class1()13 >>> b = Class1()14 >>> a == b15 55

 

[轉] http://www.cnblogs.com/lovemo1314/archive/2011/05/03/2035690.html

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.