總結(jié)Python常用的魔法方法
一、算數(shù)運算符的魔法方法
- python2.2以后,對類和類型進(jìn)行了統(tǒng)一,做法就是講int()、float()、str()、list()、tuple()這些BIF轉(zhuǎn)換為工廠函數(shù)(類對象)
- 給出以下算數(shù)運算符對應(yīng)的魔法方法,前面和后面都被雙下劃線包尾說明是魔法方法
運算符 | 對應(yīng)的魔法方法 | 中文注釋 |
+ | __ add__(self, other) | 加法 |
- | __ sub__(self, other) | 減法 |
* | __ mul__(self, other) | 乘法 |
/ | __ truediv__(self, other) | 真除法 |
// | __ floordiv__(self, other) | 整數(shù)除法 |
% | __ mod__(self, other) | 取余除法 |
divmod(a, b) | __ divmod__(self, other) | 把除數(shù)和余數(shù)運算結(jié)果結(jié)合,divmod(a,b)返回值是一個元組(a//b, a%b) |
** | __ pow__(self, other[,modulo]) | self的other次方再對modulo取余 |
<< | __ lshift__(self, other) | 按位左移 |
>> | __ rshift__(self, other) | 按位右移 |
& | __ and__(self, other) | 按位與操作 |
^ | __ xor__(self, other) | 按位異或操作(同為0,異為1) |
丨 | __ or__(self, other) | 按位或操作(有1則1) |
– | – | – |
- eg:
>>> type(len) <class 'builtin_function_or_method'> #普通的BIF >>> type(int) <class 'type'> #工廠函數(shù)(類對象),當(dāng)調(diào)用它們的時候,其實就是創(chuàng)建了一個相應(yīng)的實例對象 >>> type(dir) <class 'builtin_function_or_method'> >>> type(list) <class 'type'> >>> a = int('123') #創(chuàng)建一個相應(yīng)的實例對象a >>> b = int('345') >>> a + b #python在兩個對象進(jìn)行相加操作 468
- eg:舉個例子,下面定義一個比較特立獨行的類:
繼承int,并重寫__add__方法
>>> class New_int(int): def __add__(self,other): return int.__sub__(self,other) def __sub__(self,other): return int.__add__(self,other) >>> a = New_int(3) >>> b = New_int(5) >>> a + b #兩個對象相加,觸發(fā) __add__(self,other)方法 -2 >>> a - b 8 >>> 實例2:錯誤寫法,會造成無限遞歸 >>> class New_int(int): def __add__(self,other): return (self + other) def __sub__(self,other): return (self - other) >>> class New_int(int): def __add__(self,other): return (int(self) + int(other)) #將self與other強制轉(zhuǎn)換為整型,所以不會出現(xiàn)兩個對象相加觸發(fā)__add__()方法 def __sub__(self,other): return (int(self) - int(other)) >>> a = New_int(3) >>> b = New_int(5) >>> a + b 8
二、反運算相關(guān)的魔法方法
- 反運算相關(guān)的魔法方法
魔法方法 | 定義 |
__ radd__(self, other) | 定義加法的行為:+(當(dāng)左操作數(shù)不支持相應(yīng)的操作時被調(diào)用) |
__ rsub__(self, other) | 定義減法的行為:-(當(dāng)左操作數(shù)不支持相應(yīng)的操作時被調(diào)用) |
__ rmul__(self, other) | 定義乘法的行為:*(當(dāng)左操作數(shù)不支持相應(yīng)的操作時被調(diào)用) |
__ rtruediv__(self, other) | 定義真除法的行為:/(當(dāng)左操作數(shù)不支持相應(yīng)的操作時被調(diào)用) |
__ rfloordiv__(self, other) | 定義整數(shù)除法的行為://(當(dāng)左操作數(shù)不支持相應(yīng)的操作時被調(diào)用) |
__ rmod__(self, other) | 定義取模算法的行為:%(當(dāng)左操作數(shù)不支持相應(yīng)的操作時被調(diào)用) |
__ rdivmod__(self, other) | 定義當(dāng)被divmod()調(diào)用時的行為(當(dāng)左操作數(shù)不支持相應(yīng)的操作時被調(diào)用) |
__ rpow__(self, other) | 定義當(dāng)被power()調(diào)用或**運算時的行為(當(dāng)左操作數(shù)不支持相應(yīng)的操作時被調(diào)用) |
__ rlshift__(self, other) | 定義按位左移位的行為:<<(當(dāng)左操作數(shù)不支持相應(yīng)的操作時被調(diào)用) |
__ rrshift__(self, other) | 定義按位右移位的行為:>>(當(dāng)左操作數(shù)不支持相應(yīng)的操作時被調(diào)用) |
__ rand__(self, other) | 定義按位與操作的行為:&(當(dāng)左操作數(shù)不支持相應(yīng)的操作時被調(diào)用) |
__ rxor__(self, other) | 定義按位異或操作的行為:^(當(dāng)左操作數(shù)不支持相應(yīng)的操作時被調(diào)用) |
__ ror__(self, other) | 定義按位或操作的行為:丨(當(dāng)左操作數(shù)不支持相應(yīng)的操作時被調(diào)用) |
– | – |
>>> class int(int): def __add__(self,other): return int.__sub__(self,other) >>> a = int(3) >>> b = int(2) >>> a + b 1 反運算與算術(shù)運算符的不同之處是,反運算多了一個'r',例如 __add__()的反運算對應(yīng)為 __radd__() >>> a + b 這里a是加數(shù),b是被加數(shù),如果a對象的__add__()方法沒有實現(xiàn)或者不支持相應(yīng)的操作,那么python就會自動調(diào)用b的__radd__()方法 實例: >>> class Nint(int): def __radd__(self,other): return int.__sub__(self,other) >>> a = Nint(5) >>> b = Nint(3) >>> a + b #由于a對象默認(rèn)有__add__()方法,所以b的__radd__()沒有執(zhí)行 8 實例2: >>> class Nint(int): def __radd__(self,other): return int.__sub__(self,other) >>> b = Nint(5) >>> 3 + b #由于3無__add__()方法,所以執(zhí)行b的反運算__radd__(self,other)方法,其中self是b對象 2
eg:注:在重寫反運算魔法方法時,一定要注意順序問題。得到的應(yīng)該是個負(fù)數(shù),所以順序改變下。
三、增量賦值運算
增量賦值運算的魔法方法
魔法方法 | 定義 |
__ iadd__(self, other) | 定義賦值加法的行為:+= |
__ isub__(self, other) | 定義賦值減法的行為:-= |
__ imul__(self, other) | 定義賦值乘法的行為:*= |
__ itruediv__(self, other) | 定義賦值真除法的行為:/= |
__ ifloordiv__(self, other) | 定義賦值整數(shù)除法的行為://= |
__ imod__(self, other) | 定義賦值取模算法的行為:%= |
__ ipow__(self, other) | 定義賦值冪運算的行為:**= |
__ ilshift__(self, other) | 定義賦值按位左移位的行為:<<= |
__ irshift__(self, other) | 定義賦值按位右移位的行為:>>= |
__ iand__(self, other) | 定義賦值按位與操作的行為:&= |
__ ixor__(self, other) | 定義賦值按位異或操作的行為:^= |
__ ior__(self, other) | 定義賦值按位或操作的行為:丨= |
- | - |
四、一元操作符
- 一元操作符的魔法方法
魔法方法 | 定義 |
__ neg__(self) | 定義正號的行為:+x |
__ pos__(self) | 定義負(fù)號的行為:-x |
__ abs__(self) | 定義當(dāng)被abs()調(diào)用時的行為 |
__ invert__(self) | 定義按位求反的行為:~x |
– | – |
到此這篇關(guān)于總結(jié)Python常用的魔法方法的文章就介紹到這了,更多相關(guān)Python魔法方法內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Python繪圖之實現(xiàn)繪制極坐標(biāo)圖像
這篇文章主要介紹了如何利用python繪制極坐標(biāo)圖像,文中的示例代碼講解詳細(xì),具有一定的的參考價值,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2023-08-08分析python并發(fā)網(wǎng)絡(luò)通信模型
隨著互聯(lián)網(wǎng)和物聯(lián)網(wǎng)的高速發(fā)展,使用網(wǎng)絡(luò)的人數(shù)和電子設(shè)備的數(shù)量急劇增長,其也對互聯(lián)網(wǎng)后臺服務(wù)程序提出了更高的性能和并發(fā)要求。本文主要分析比較了一些模型的優(yōu)缺點,并且用python來實現(xiàn)2021-06-06淺談numpy.where() 的用法和np.argsort()的用法說明
這篇文章主要介紹了淺談numpy.where() 的用法和np.argsort()的用法說明,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-05-05Python?pandas數(shù)據(jù)合并merge函數(shù)用法詳解
這篇文章主要給大家介紹了關(guān)于Python?pandas數(shù)據(jù)合并merge函數(shù)用法的相關(guān)資料,數(shù)據(jù)分析中經(jīng)常會遇到數(shù)據(jù)合并的基本問題,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-07-07Tornado Web服務(wù)器多進(jìn)程啟動的2個方法
這篇文章主要介紹了Tornado Web服務(wù)器多進(jìn)程啟動的2個方法,Tornado是一個用Ptyhon寫的WEB服務(wù)器,需要的朋友可以參考下2014-08-08Python實現(xiàn)圖片和base64轉(zhuǎn)換詳解
這篇文章主要介紹了Python實現(xiàn)圖片和base64轉(zhuǎn)換詳解,Base64是一種二進(jìn)制到文本的編碼方式,如果要更具體一點的話,可以認(rèn)為它是一種將 byte數(shù)組編碼為字符串的方法,而且編碼出的字符串只包含ASCII基礎(chǔ)字符,需要的朋友可以參考下2024-01-01