
文章來源: Python貓
作者: 豌豆花下貓
關(guān)于 python 中的pass語句,它似乎很簡單(只有 4 個字母),即使是沒有任何編程經(jīng)驗的初學(xué)者也能很快地掌握它的用法。
官方文檔 的介紹十分簡單,下面的三個例子可以讓我們快速地了解到如何使用它:
簡單而言,pass 是一種空操作(null operation),解釋器執(zhí)行到它的時候,除了檢查語法是否合法,什么也不做就直接跳過。
它跟 return、break、continue 和 yield 之類的非空操作相比,最大的區(qū)別是它不會改變程序的執(zhí)行順序。它就像我們寫的注釋,除了占用一行代碼行,不會對所處的作用域產(chǎn)生任何影響。
但是,如果你有其它語言的基礎(chǔ),你也許會好奇:為什么 Python 有這么獨特的 pass 語句,而別的語言卻沒有?
python 這么設(shè)計,到底是出于什么原因呢?
是為了解決大部分編程語言都要面對的共性問題,還是因為它有自己的新發(fā)現(xiàn),所以創(chuàng)造出來一個新的特性?
換句話說:Python 為什么要有 pass 語句,它能解決什么問題(好處),如果沒有它,會導(dǎo)致什么問題(壞處)?
接下來,本文將從兩個維度展開分析。
我把它看作是一種言簡意賅的注釋方式,等于是說“這里先預(yù)留位置,回頭再補(bǔ)上具體的代碼實現(xiàn)”。
比如在多層的 if-elif-else 結(jié)構(gòu)中,我們可以先把判斷條件寫好,然后在對應(yīng)的塊中寫上 pass,以后再慢慢完善。
比如上文中給出的例子,我們可以先寫好類/函數(shù)名及其入?yún)?,然后跳過(pass)主體代碼,以后再慢慢填充。
pass 寫起來簡單,而且由于是關(guān)鍵字,IDE 會給出顯眼的顏色區(qū)分,所以就比我們寫上注釋內(nèi)容來得方便些。
pass 作為空間占位符,主要可以方便我們構(gòu)思局部的代碼結(jié)構(gòu),有一定的輔助提醒作用。
但是,若作為一種注釋方式,它就顯得太單薄了,比不上寫“# todo: xxxx”,后者也會被 IDE 用顏色突顯,而且意思更明確。雖然寫起來簡單,但它也引入了一個看似多余的關(guān)鍵字 pass。
所以,從空間占位符的角度來看,pass 不是編程語言中必須的設(shè)計要素。
有了它,我們可以表達(dá)出“此處有東西,但暫時跳過”的語義,但如果沒有它,則可以用注釋內(nèi)容來替代。
對于前一條的用法,pass 出現(xiàn)在代碼中的位置在理論上是不受限的。
但是,我們最常使用 pass 時,基本是在冒號的下一行,而且在該層縮進(jìn)的代碼塊中,只有這一條語句。(參見前文的 3 個例子,為了方便,我們僅以以空函數(shù)為例)
我們可以設(shè)想下,如果不寫它,會怎樣?
答案是會報縮進(jìn)錯誤:IndentationError: expected an indented block
# 將函數(shù)體的 pass 去除,會報錯 def func(): func()
因為 Python 使用縮進(jìn)來劃分代碼塊(至于原因,請查閱《Python為什么使用縮進(jìn)來劃分代碼塊?》),而冒號標(biāo)識著要出現(xiàn)新的縮進(jìn)代碼塊,所以這個例子會報缺少縮進(jìn)代碼塊。
如果我們用前文說的注釋來替代,看看會怎樣?
# 將函數(shù)體的 pass 換成注釋 def func(): # todo:此處有東西,以后補(bǔ)上 func()
這樣寫,也會報錯:IndentationError: expected an indented block
原因是注釋并非有效的語法內(nèi)容,它會被 Python 解釋器忽略掉(ignore),不像 pass 語句那樣是“有效的語法內(nèi)容,但是跳過”。
也就是說,縮進(jìn)代碼塊中必須包含有語法意義的內(nèi)容,下面的例子都是有效的:
def func(): """這是一個字符串""" def func2(): 123456
Python 在定義函數(shù)時,必須包含函數(shù)體,即同時包含聲明加定義兩種語義,不能像某些語言可以只使用聲明的語義,即寫成void test(); 。
但是,由于 Python 不使用花括號,它無法像某些語言那樣直接定義出空函數(shù),即寫成void test(){} 。
綜合以上的分析,Python 在定義空函數(shù)時,必須要有合法的函數(shù)體,因此設(shè)計出表示空操作的 pass 語句。它是為了補(bǔ)充語法的完整性,連同冒號,等效于其它語言中一對空的花括號。
從語法完整性的維度上看,它是必須的設(shè)計要素,如果沒有的話,也必須用類似的空語句或特殊符號來替代。
對人方面,pass 可以表示“暫時跳過”的含義,作為臨時的占位符,最終會被實際的代碼實現(xiàn)所替換;對機(jī)器方面,它則可以表示“直接跳過”,只為了補(bǔ)齊語法邏輯,并不會被其它代碼所替換。
其它語言沒有專門的一種語句或者符號來表示這種占位符(即語義有所欠缺),但是它們也不需要費心思專門設(shè)計一個關(guān)鍵字來補(bǔ)齊語法完整性(即語法完備)。
回到本文開頭的問題:Python 為什么要有 pass 語句,它能解決什么問題(好處),如果沒有它,會導(dǎo)致什么問題(壞處)?
Python 使用 pass 語句,是為了支持純粹空操作的代碼塊(空函數(shù)、空類、空的循環(huán)控制塊等等),有了它,還能額外表達(dá)出一種占位符的語義。
前者是對于機(jī)器而言的,必須要有,等效于其它語言中空花括號的作用;后者是對于人而言的,非必須的,可以用注釋來表達(dá),但因為 Python 設(shè)計了這個語句,這種用法有時候還挺方便的。
數(shù)據(jù)分析咨詢請掃描二維碼
若不方便掃碼,搜微信號:CDAshujufenxi
SQL Server 中 CONVERT 函數(shù)的日期轉(zhuǎn)換:從基礎(chǔ)用法到實戰(zhàn)優(yōu)化 在 SQL Server 的數(shù)據(jù)處理中,日期格式轉(zhuǎn)換是高頻需求 —— 無論 ...
2025-09-18MySQL 大表拆分與關(guān)聯(lián)查詢效率:打破 “拆分必慢” 的認(rèn)知誤區(qū) 在 MySQL 數(shù)據(jù)庫管理中,“大表” 始終是性能優(yōu)化繞不開的話題。 ...
2025-09-18CDA 數(shù)據(jù)分析師:表結(jié)構(gòu)數(shù)據(jù) “獲取 - 加工 - 使用” 全流程的賦能者 表結(jié)構(gòu)數(shù)據(jù)(如數(shù)據(jù)庫表、Excel 表、CSV 文件)是企業(yè)數(shù)字 ...
2025-09-18DSGE 模型中的 Et:理性預(yù)期算子的內(nèi)涵、作用與應(yī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ù)特征價值的專業(yè)核心 表結(jié)構(gòu)數(shù)據(jù)(以 “行 - 列” 規(guī)范存儲的結(jié)構(gòu)化數(shù)據(jù),如數(shù)據(jù)庫表、Excel 表、 ...
2025-09-17Excel 導(dǎo)入數(shù)據(jù)含缺失值?詳解 dropna 函數(shù)的功能與實戰(zhàn)應(yīng)用 在用 Python(如 pandas 庫)處理 Excel 數(shù)據(jù)時,“缺失值” 是高頻 ...
2025-09-16深入解析卡方檢驗與 t 檢驗:差異、適用場景與實踐應(yīng)用 在數(shù)據(jù)分析與統(tǒng)計學(xué)領(lǐng)域,假設(shè)檢驗是驗證研究假設(shè)、判斷數(shù)據(jù)差異是否 “ ...
2025-09-16CDA 數(shù)據(jù)分析師:掌控表格結(jié)構(gòu)數(shù)據(jù)全功能周期的專業(yè)操盤手 表格結(jié)構(gòu)數(shù)據(jù)(以 “行 - 列” 存儲的結(jié)構(gòu)化數(shù)據(jù),如 Excel 表、數(shù)據(jù) ...
2025-09-16MySQL 執(zhí)行計劃中 rows 數(shù)量的準(zhǔn)確性解析:原理、影響因素與優(yōu)化 在 MySQL SQL 調(diào)優(yōu)中,EXPLAIN執(zhí)行計劃是核心工具,而其中的row ...
2025-09-15解析 Python 中 Response 對象的 text 與 content:區(qū)別、場景與實踐指南 在 Python 進(jìn)行 HTTP 網(wǎng)絡(luò)請求開發(fā)時(如使用requests ...
2025-09-15CDA 數(shù)據(jù)分析師:激活表格結(jié)構(gòu)數(shù)據(jù)價值的核心操盤手 表格結(jié)構(gòu)數(shù)據(jù)(如 Excel 表格、數(shù)據(jù)庫表)是企業(yè)最基礎(chǔ)、最核心的數(shù)據(jù)形態(tài) ...
2025-09-15Python HTTP 請求工具對比:urllib.request 與 requests 的核心差異與選擇指南 在 Python 處理 HTTP 請求(如接口調(diào)用、數(shù)據(jù)爬取 ...
2025-09-12解決 pd.read_csv 讀取長浮點數(shù)據(jù)的科學(xué)計數(shù)法問題 為幫助 Python 數(shù)據(jù)從業(yè)者解決pd.read_csv讀取長浮點數(shù)據(jù)時的科學(xué)計數(shù)法問題 ...
2025-09-12CDA 數(shù)據(jù)分析師:業(yè)務(wù)數(shù)據(jù)分析步驟的落地者與價值優(yōu)化者 業(yè)務(wù)數(shù)據(jù)分析是企業(yè)解決日常運營問題、提升執(zhí)行效率的核心手段,其價值 ...
2025-09-12用 SQL 驗證業(yè)務(wù)邏輯:從規(guī)則拆解到數(shù)據(jù)把關(guān)的實戰(zhàn)指南 在業(yè)務(wù)系統(tǒng)落地過程中,“業(yè)務(wù)邏輯” 是連接 “需求設(shè)計” 與 “用戶體驗 ...
2025-09-11塔吉特百貨孕婦營銷案例:數(shù)據(jù)驅(qū)動下的精準(zhǔn)零售革命與啟示 在零售行業(yè) “流量紅利見頂” 的當(dāng)下,精準(zhǔn)營銷成為企業(yè)突圍的核心方 ...
2025-09-11CDA 數(shù)據(jù)分析師與戰(zhàn)略 / 業(yè)務(wù)數(shù)據(jù)分析:概念辨析與協(xié)同價值 在數(shù)據(jù)驅(qū)動決策的體系中,“戰(zhàn)略數(shù)據(jù)分析”“業(yè)務(wù)數(shù)據(jù)分析” 是企業(yè) ...
2025-09-11Excel 數(shù)據(jù)聚類分析:從操作實踐到業(yè)務(wù)價值挖掘 在數(shù)據(jù)分析場景中,聚類分析作為 “無監(jiān)督分組” 的核心工具,能從雜亂數(shù)據(jù)中挖 ...
2025-09-10統(tǒng)計模型的核心目的:從數(shù)據(jù)解讀到?jīng)Q策支撐的價值導(dǎo)向 統(tǒng)計模型作為數(shù)據(jù)分析的核心工具,并非簡單的 “公式堆砌”,而是圍繞特定 ...
2025-09-10