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