
Python進(jìn)階學(xué)習(xí)之特殊方法實(shí)例詳析
最近在學(xué)習(xí)python,學(xué)習(xí)到了一個(gè)之前沒接觸過的--特殊方法。
什么是特殊方法?當(dāng)我們?cè)谠O(shè)計(jì)一個(gè)類的時(shí)候,python中有一個(gè)用于初始化的方法$__init__$,類似于java中的構(gòu)造器,這個(gè)就是特殊方法,也叫作魔術(shù)方法。簡(jiǎn)單來說,特殊方法可以給你設(shè)計(jì)的類加上一些神奇的特性,比如可以進(jìn)行python原生的切片操作,迭代、連乘操作等。在python中,特殊方法以雙下劃線開始,以雙下劃線結(jié)束。
一個(gè)大例子
數(shù)學(xué)中有一個(gè)表示數(shù)的概念叫做向量,但是python中的數(shù)據(jù)類型卻沒有。我們來設(shè)法用python實(shí)現(xiàn)它。
首先考慮,向量跟普通的數(shù)據(jù)類型不同,傳統(tǒng)的數(shù)可以直接進(jìn)行運(yùn)算,向量則需要對(duì)不同的坐標(biāo)分別運(yùn)算。來試試。
首先定義一個(gè)類,實(shí)現(xiàn)初始化方法。
# 實(shí)現(xiàn)向量類型
class Vector:
def __init__(self, x=0, y=0):
self.x = x
self.y = y
如何實(shí)現(xiàn)向量的加法?二維向量中,向量的加法就是每個(gè)坐標(biāo)分別相加得到的結(jié)果。在python中有個(gè)$__add__$方法,用來進(jìn)行加法操作。
class Vector:
def __init__(self, x=0, y=0):
self.x = x
self.y = y
# 實(shí)現(xiàn)向量加法
def __add__(self, other):
x = self.x + other.x
y = self.y + other.y
return Vector(x, y)
我們對(duì)x和y變量分別進(jìn)行相加,然后返回Vector。在python你可以對(duì)字符串直接用加法拼接起來的原理就在此,python實(shí)現(xiàn)了針對(duì)字符串的add方法。
實(shí)現(xiàn)了加法,乘法的道理一樣,分別對(duì)每個(gè)坐標(biāo)單獨(dú)相乘即可。
class Vector:
def __init__(self, x=0, y=0):
self.x = x
self.y = y
# 實(shí)現(xiàn)向量加法
def __add__(self, other):
x = self.x + other.x
y = self.y + other.y
return Vector(x, y)
# 實(shí)現(xiàn)向量乘法,例如r*3
def __mul__(self, scalar):
return Vector(self.x*scalar, self.y*scalar)
我們?cè)谶M(jìn)行向量運(yùn)算時(shí)還有一個(gè)常用的操作是求向量的模,我們用$__abs__$特殊方法來實(shí)現(xiàn),abs一般用來求一個(gè)數(shù)的絕對(duì)值,向量用不到,用來求模剛好合適。使用math模塊中的hypot方法計(jì)算$\sqrt(x^2+y^2)$。
class Vector:
def __init__(self, x=0, y=0):
self.x = x
self.y = y
# 真假值,如果向量模為0,返回false
def __bool__(self):
return bool(abs(self))
# 實(shí)現(xiàn)向量加法
def __add__(self, other):
x = self.x + other.x
y = self.y + other.y
return Vector(x, y)
# 實(shí)現(xiàn)向量乘法,例如r*3
def __mul__(self, scalar):
return Vector(self.x*scalar, self.y*scalar)
# 返回向量的模
# hypot()返回歐幾里德范數(shù) sqrt(x*x + y*y)
def __abs__(self):
return hypot(self.x, self.y)
找個(gè)例子運(yùn)行下。
v = Vector(2, 3)
print(v)
v2 = Vector(4, 5)
print(v+v2)
print(v+v2*2)
<__main__.Vector object at 0x000002B4B1843C50>
<__main__.Vector object at 0x000002B4B1843EF0>
<__main__.Vector object at 0x000002B4B1843898>
可以運(yùn)行了,貌似是正確的,但是輸出的結(jié)果很奇怪。怎么辦?python中有個(gè)$__repr__$特殊方法,可以修改控制臺(tái)輸出的樣式。
class Vector:
def __init__(self, x=0, y=0):
self.x = x
self.y = y
# 真假值,如果向量模為0,返回false
def __bool__(self):
return bool(abs(self))
# 實(shí)現(xiàn)向量加法
def __add__(self, other):
x = self.x + other.x
y = self.y + other.y
return Vector(x, y)
# 實(shí)現(xiàn)向量乘法,例如r*3
def __mul__(self, scalar):
return Vector(self.x*scalar, self.y*scalar)
# 返回向量的模
# hypot()返回歐幾里德范數(shù) sqrt(x*x + y*y)
def __abs__(self):
return hypot(self.x, self.y)
# 實(shí)現(xiàn)__repr__方法,在控制臺(tái)打印向量時(shí)會(huì)輸出Vector(1, 2)
# 實(shí)現(xiàn)__str__,使用str()返回字符串
def __repr__(self):
return 'Vector(%r, %r)' % (self.x, self.y)
實(shí)現(xiàn)了$__repr__$方法,我們就可以在控制臺(tái)輸出Vecotor(x,y)。與之對(duì)應(yīng)的有個(gè)$__str__$方法,使用str()返回相應(yīng)的字符串,展示給用戶。
現(xiàn)在來看下之前程序運(yùn)行的結(jié)果。
v = Vector(2, 3)
print(v)
v2 = Vector(4, 5)
print(v+v2)
print(v+v2*2)
print(abs(v))
Vector(2, 3)
Vector(6, 8)
Vector(10, 13)
3.605551275463989
效果不錯(cuò)。
通過實(shí)現(xiàn)特殊方法,自定義類型可以表現(xiàn)的跟內(nèi)置類型一樣,讓我們能夠?qū)懗龈哂?a href='/map/python/' style='color:#000;font-size:inherit;'>python風(fēng)格的代碼。
除了上面說到的幾個(gè)特殊方法外,python還有差不多80多個(gè)特殊方法,比如$__len__$方法可以用來求長(zhǎng)度,$__getitem__$可以使用haha[2]之類的操作進(jìn)行切片和迭代等,同樣的還有$__setitem__$。
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值
數(shù)據(jù)分析咨詢請(qǐng)掃描二維碼
若不方便掃碼,搜微信號(hào):CDAshujufenxi
SQL Server 中 CONVERT 函數(shù)的日期轉(zhuǎn)換:從基礎(chǔ)用法到實(shí)戰(zhàn)優(yōu)化 在 SQL Server 的數(shù)據(jù)處理中,日期格式轉(zhuǎn)換是高頻需求 —— 無論 ...
2025-09-18MySQL 大表拆分與關(guān)聯(lián)查詢效率:打破 “拆分必慢” 的認(rèn)知誤區(qū) 在 MySQL 數(shù)據(jù)庫(kù)管理中,“大表” 始終是性能優(yōu)化繞不開的話題。 ...
2025-09-18CDA 數(shù)據(jù)分析師:表結(jié)構(gòu)數(shù)據(jù) “獲取 - 加工 - 使用” 全流程的賦能者 表結(jié)構(gòu)數(shù)據(jù)(如數(shù)據(jù)庫(kù)表、Excel 表、CSV 文件)是企業(yè)數(shù)字 ...
2025-09-18DSGE 模型中的 Et:理性預(yù)期算子的內(nèi)涵、作用與應(yīng)用解析 動(dòng)態(tài)隨機(jī)一般均衡(Dynamic Stochastic General Equilibrium, DSGE)模 ...
2025-09-17Python 提取 TIF 中地名的完整指南 一、先明確:TIF 中的地名有哪兩種存在形式? 在開始提取前,需先判斷 TIF 文件的類型 —— ...
2025-09-17CDA 數(shù)據(jù)分析師:解鎖表結(jié)構(gòu)數(shù)據(jù)特征價(jià)值的專業(yè)核心 表結(jié)構(gòu)數(shù)據(jù)(以 “行 - 列” 規(guī)范存儲(chǔ)的結(jié)構(gòu)化數(shù)據(jù),如數(shù)據(jù)庫(kù)表、Excel 表、 ...
2025-09-17Excel 導(dǎo)入數(shù)據(jù)含缺失值?詳解 dropna 函數(shù)的功能與實(shí)戰(zhàn)應(yīng)用 在用 Python(如 pandas 庫(kù))處理 Excel 數(shù)據(jù)時(shí),“缺失值” 是高頻 ...
2025-09-16深入解析卡方檢驗(yàn)與 t 檢驗(yàn):差異、適用場(chǎng)景與實(shí)踐應(yīng)用 在數(shù)據(jù)分析與統(tǒng)計(jì)學(xué)領(lǐng)域,假設(shè)檢驗(yàn)是驗(yàn)證研究假設(shè)、判斷數(shù)據(jù)差異是否 “ ...
2025-09-16CDA 數(shù)據(jù)分析師:掌控表格結(jié)構(gòu)數(shù)據(jù)全功能周期的專業(yè)操盤手 表格結(jié)構(gòu)數(shù)據(jù)(以 “行 - 列” 存儲(chǔ)的結(jié)構(gòu)化數(shù)據(jù),如 Excel 表、數(shù)據(jù) ...
2025-09-16MySQL 執(zhí)行計(jì)劃中 rows 數(shù)量的準(zhǔn)確性解析:原理、影響因素與優(yōu)化 在 MySQL SQL 調(diào)優(yōu)中,EXPLAIN執(zhí)行計(jì)劃是核心工具,而其中的row ...
2025-09-15解析 Python 中 Response 對(duì)象的 text 與 content:區(qū)別、場(chǎng)景與實(shí)踐指南 在 Python 進(jìn)行 HTTP 網(wǎng)絡(luò)請(qǐng)求開發(fā)時(shí)(如使用requests ...
2025-09-15CDA 數(shù)據(jù)分析師:激活表格結(jié)構(gòu)數(shù)據(jù)價(jià)值的核心操盤手 表格結(jié)構(gòu)數(shù)據(jù)(如 Excel 表格、數(shù)據(jù)庫(kù)表)是企業(yè)最基礎(chǔ)、最核心的數(shù)據(jù)形態(tài) ...
2025-09-15Python HTTP 請(qǐng)求工具對(duì)比:urllib.request 與 requests 的核心差異與選擇指南 在 Python 處理 HTTP 請(qǐng)求(如接口調(diào)用、數(shù)據(jù)爬取 ...
2025-09-12解決 pd.read_csv 讀取長(zhǎng)浮點(diǎn)數(shù)據(jù)的科學(xué)計(jì)數(shù)法問題 為幫助 Python 數(shù)據(jù)從業(yè)者解決pd.read_csv讀取長(zhǎng)浮點(diǎn)數(shù)據(jù)時(shí)的科學(xué)計(jì)數(shù)法問題 ...
2025-09-12CDA 數(shù)據(jù)分析師:業(yè)務(wù)數(shù)據(jù)分析步驟的落地者與價(jià)值優(yōu)化者 業(yè)務(wù)數(shù)據(jù)分析是企業(yè)解決日常運(yùn)營(yíng)問題、提升執(zhí)行效率的核心手段,其價(jià)值 ...
2025-09-12用 SQL 驗(yàn)證業(yè)務(wù)邏輯:從規(guī)則拆解到數(shù)據(jù)把關(guān)的實(shí)戰(zhàn)指南 在業(yè)務(wù)系統(tǒng)落地過程中,“業(yè)務(wù)邏輯” 是連接 “需求設(shè)計(jì)” 與 “用戶體驗(yàn) ...
2025-09-11塔吉特百貨孕婦營(yíng)銷案例:數(shù)據(jù)驅(qū)動(dòng)下的精準(zhǔn)零售革命與啟示 在零售行業(yè) “流量紅利見頂” 的當(dāng)下,精準(zhǔn)營(yíng)銷成為企業(yè)突圍的核心方 ...
2025-09-11CDA 數(shù)據(jù)分析師與戰(zhàn)略 / 業(yè)務(wù)數(shù)據(jù)分析:概念辨析與協(xié)同價(jià)值 在數(shù)據(jù)驅(qū)動(dòng)決策的體系中,“戰(zhàn)略數(shù)據(jù)分析”“業(yè)務(wù)數(shù)據(jù)分析” 是企業(yè) ...
2025-09-11Excel 數(shù)據(jù)聚類分析:從操作實(shí)踐到業(yè)務(wù)價(jià)值挖掘 在數(shù)據(jù)分析場(chǎng)景中,聚類分析作為 “無監(jiān)督分組” 的核心工具,能從雜亂數(shù)據(jù)中挖 ...
2025-09-10統(tǒng)計(jì)模型的核心目的:從數(shù)據(jù)解讀到?jīng)Q策支撐的價(jià)值導(dǎo)向 統(tǒng)計(jì)模型作為數(shù)據(jù)分析的核心工具,并非簡(jiǎn)單的 “公式堆砌”,而是圍繞特定 ...
2025-09-10