Python基礎知識詳解 從入門到精通(八)魔法方法

Python基礎知識詳解 從入門到精通(八)魔法方法

其他python學習筆記集合

Python基礎知識詳解 從入門到精通 全集索引篇

什麼是魔法方法

顧名思義魔法方法就是可以給你的類的操作附加’魔力‘的方法,給予了我們非常大的靈活性,在我們需要時候爲我們提供了某種方法來讓你的想法實現,衆所周知Python是支持面向對象的語言,Python的魔法方法就使得Python在面對對象方面做得更好

怎麼用魔法方法

魔法方法是python內部已經給定的了,它被雙下劃線包圍着,在一些特定的時候它會被自動的調用

我們可以改寫某一個魔法方法,定義好我們需要進行的操作,在這個魔法方法被自動調用時候也就完成了我們需要的操作

基礎魔法方法(較爲常用)

  1. __ new__(cls[, …])
    1.實例化對象時第一個被調用的方法
    2.其參數直接傳遞給__ init__方法處理
    3.我們一般不會重寫該方法
    4.當繼承一個不可變類型又需要修改時候就需要修改他
  2. __ init__(self[, …])
    構造方法,初始化類(生成實例的可以傳入參數)的時候被調用
  3. __ del__(self)
    析構方法,當實例化對象被徹底銷燬(沒有標籤指向這個對象 )時被調用(實例化對象的所有指針都被銷燬時被調用)並非是使用del時調用,它相當於垃圾回收機制
  4. __ call__(self[, args…])
    允許一個類的實例像函數一樣被調用:x(a, b) 調用 x.__ call__(a, b)
  5. __ len__(self)
    定義 當被 len() 調用時的行爲
  6. __ repr__(self)
    定義當被 repr() 調用時的行爲 改寫這個可以實現返回字符串
 class h :
	 def __repr__(self):
		return xxx
     		則 a = h()
			運行a 
			結果直接輸出xxx

  1. __ str__(self)
    定義當被 str() 調用時的行爲,改寫這個可以實現返回字符串
 class h :
	 def __str__(self):
	    return xxx
     		則 a = h()
			結果返回xxxx
 			Print(a)時輸出xxx 
  1. __ bytes__(self) 定義當被 bytes() 調用時的行爲
  2. __ hash__(self) 定義當被 hash() 調用時的行爲
  3. __ bool__(self) 定義當被 bool() 調用時的行爲,應該返回 True 或 False
  4. __ format__(self, format_spec) 定義當被 format() 調用時的行爲
    屬性相關的方法
  5. __ getattr__(self, name) 定義當用戶試圖獲取一個不存在的屬性時的行爲
  6. __ getattribute__(self, name) 定義當該類的屬性被訪問時的行爲
  7. __ setattr__(self, name, value) 定義當一個屬性被設置時的行爲
  8. __ delattr__(self, name) 定義當一個屬性被刪除時的行爲
  9. __ dir__(self) 定義當 dir() 被調用時的行爲
  10. __ get__(self, instance, owner) 定義當描述符的值被取得時的行爲
  11. __ set__(self, instance, value) 定義當描述符的值被改變時的行爲
  12. __ delete__(self, instance) 定義當描述符的值被刪除時的行爲

比較操作符

__ lt__(self, other) 定義小於號的行爲:x < y 調用 x.__ lt__(y)
__ le__(self, other) 定義小於等於號的行爲:x <= y 調用 x.__ le__(y)
__ eq__(self, other) 定義等於號的行爲:x == y 調用 x.__ eq__(y)
__ ne__(self, other) 定義不等號的行爲:x != y 調用 x.__ ne__(y)
__ gt__(self, other) 定義大於號的行爲:x > y 調用 x.__ gt__(y)
__ ge__(self, other) 定義大於等於號的行爲:x >= y 調用 x.__ ge__(y)

算數運算符

__ add__(self, other) 定義加法的行爲:+
__ sub__(self, other) 定義減法的行爲:-
__ mul__(self, other) 定義 乘法的行爲:*
__ truediv__(self, other) 定義真除法的行爲:/
__ floordiv__(self, other) 定義整數除法的行爲://
__ mod__(self, other) 定義取模算法的行爲:%
__ divmod__(self, other) 定義當被 divmod() 調用時的行爲
__ pow__(self, other[, modulo]) 定義當被 power() 調用或 ** 運算時的行爲
__ lshift__(self, other) 定義按位左移位的行爲:<<
__ rshift__(self, other) 定義按位右移位的行爲:>>
__ and__(self, other) 定義按位與操作的行爲:&
__ xor__(self, other) 定義按位異或操作的行爲:^
__ or__(self, other) 定義按位或操作的行爲:|

反運算(類似於運算方法)

__ radd__(self, other) 當被運算對象(左邊的操作對象)不支持該運算時被調用
__ rsub__(self, other) 當被運算對象(左邊的操作對象)不支持該運算時被調用
__ rmul__(self, other) 當被運算對象(左邊的操作對象)不支持該運算時被調用
__ rtruediv__(self, other) 當被運算對象(左邊的操作對象)不支持該運算時被調用
__ rfloordiv__(self, other) 當被運算對象(左邊的操作對象)不支持該運算時被調 用
__ rmod__(self, other) 當被運算對象(左邊的操作對象)不支持該運算時被調用
__ rdivmod__(self, other) 當被運算對象(左邊的操作對象)不支持該運算時被調用
__ rpow__(self, other) 當被運算對象(左邊的操作對象)不支持該運算時被調用
__ rlshift__(self, other) 當被運算對象(左邊的操作對象)不支持該運算時被調用
__ rrshift__(self, other) 當被運算對象(左邊的操作對象)不支持該運算時被調用
__ rxor__(self, other) 當被運算對象(左邊的操作對象)不支持該運算時被調用
__ ror__(self, other) 當被運算對象(左邊的操作對象)不支持該運算時被調用

增量賦值運算

__ iadd__(self, other) 定義賦值加法的行爲:+=
__ isub__(self, other) 定義賦值減法的行爲:-=
__ imul__(self, other) 定義賦值乘法的行爲:*=
__ itruediv__(self, other) 定義賦值真除法的行爲:/=
__ ifloordiv__(self, other) 定義賦值整數除法的行爲://=
__ imod__(self, other) 定義賦值取模算法的行爲:%=
__ ipow__(self, other[, modulo]) 定義賦值冪運算的行爲:**=
__ ilshift__(self, other) 定義賦值按位左移位的行爲:<<=
__ irshift__(self, other) 定義賦值按位右移位的行爲:>>=
__ iand__(self, other) 定義賦值按位與操作的行爲:&=
__ ixor__(self, other) 定義賦值按位異或操作的行爲:^=
__ ior__(self, other) 定義賦值按位或操作的行爲:|=

一元操作符

__ neg__(self) 定義正號的行爲:+x
__ pos__(self) 定義負號的行爲:-x
__ abs__(self) 定義當被 abs() 調用時的行爲
__ invert__(self) 定義按位求反的行爲:~x

類型轉換

__ complex__(self) 定義當被 complex() 調用時的行爲(需要返回恰當的值)
__ int__(self) 定義當被 int() 調用時的行爲(需要返回恰當的值)
__ float__(self) 定義當被 float() 調用時的行爲(需要返回恰當的值)
__ round__(self[, n]) 定義當被 round() 調用時的行爲(需要返回恰當的值)

__ index__(self)

  1. 當對象是被應用在切片表達式中時,實現整形強制轉換
  2. 如果你定義了一個可能在切片時用到的定製的數值型,你應該定義 __ index__
  3. 如果 __ index __ 被定義,則 __ int__ 也需要被定義,且返回相同的值

上下文管理(with 語句)

  1. __ enter__(self) 1. 定義當使用 with 語句時的初始化行爲
  2. __ enter__ 的返回值被 with 語句的目標或者 as 後的名字綁定
  3. __ exit__(self, exc_type, exc_value, traceback)
  4. 定義當一個代碼塊被執行或者終止後上下文管理器應該做什麼
  5. 一般被用來處理異常,清除工作或者做一些代碼塊執行完畢之後的日常工作
    容器類型(一般用於操作容器類)
  6. __ len__(self) 定義當被 len() 調用時的行爲(一般返回容器類的長度)
  7. __ getitem__(self, key) 定義獲取容器中指定元素的行爲,相當於 self[key]
  8. __ setitem__(self, key, value) 定義設置容器中指定元素的行爲,相當於 self[key] = value
  9. __ delitem__(self, key) 定義刪除容器中指定元素的行爲,相當於 del self[key]
  10. __ iter__(self) 定義當迭代容器中的元素的行爲
  11. __ reversed__(self) 定義當被 reversed() 調用時的行爲
  12. __ contains__(self, item) 定義當使用成員測試運算符(in 或 not in)時的行爲

定製容器

如果定製不可變容器需要定義 __len__和__getitem__方法
若可變 容器 需要定義__len__和__getitem__方法還有__setitem__和__delitem__方法

例子 定製一個不可變自定義列表,要求記錄每個元素被訪問個次數

class mylist:
	del __init__(self,*args):
		self.values = [x for x in args]    #將*args的元素放入列表中
#(x for x in args) 是一個列表推導式,,,
        self.count = {}.fromkeys(range(len(self.values)),0)
	def __len__(self):
		return len (self.values)
	def __getitem__(self,key):
		self.count[key] += 1
		return self.values[key]

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章