
文章來源: Python貓
作者:豌豆花下貓
在 C/C++/Java 等等語言中,整型變量的自增或自減操作是標配,它們又可分為前綴操作(++i 和 --i)與后綴操作(i++ 和 i--),彼此存在著一些細微差別,各有不同的用途。
這些語言的使用者在接觸 Python 時,可能會疑惑為什么它不提供 ++ 或 -- 的操作呢?在我前不久發(fā)的《Python的十萬個為什么?》里,就有不少同學在調查問卷中表示了對此話題感興趣。
Python 中雖然可能出現(xiàn) ++i 這種前綴形式的寫法,但是它并沒有“++”自增操作符,此處只是兩個“+”(正數(shù)符號)的疊加而已,至于后綴形式的“++”,則完全不支持(SyntaxError: invalid syntax)。
本期“Python為什么”欄目,我們將會從兩個主要的角度來回答:Python 為什么不支持 i++ 自增語法?(PS:此處自增指代“自增和自減”,下同)
首先,Python 當然可以實現(xiàn)自增效果,即寫成i+=1或者i=i+1,這在其它語言中也是通用的。
雖然 Python 在底層用了不同的魔術方法(__add__()和__iadd__())來完成計算,但表面上的效果完全相同。
所以,我們的問題可以轉化成:為什么上面的兩種寫法會勝過 i++,成為 Python 的最終選擇呢?
當我們定義i = 1000時,不同語言會作出不同的處理:
所以當我們令i“自增”時(i=i+1),它們的處理是不同的:
打一個不太恰當?shù)谋确剑篊 中的 i 就像一個宿主,數(shù)字 1000 寄生在它上面;而 Python 中的 1000 像個宿主,名稱 i 寄生在它上面。C 中的 i 與 Python 中的 1000,它們則寄生在底層的內(nèi)存空間上……
還可以這樣理解:C 中的變量 i 是一等公民,數(shù)字 1000 是它的一個可變的屬性;Python 中的數(shù)字 1000 是一等公民,名稱 i 是它的一個可變的屬性。
有了以上的鋪墊,我們再來看看i++,不難發(fā)現(xiàn):
Python 若支持 i++,其操作過程要比 C 的 i++ 復雜,而且其含義也不再是“令數(shù)字增加1”(自增),而是“創(chuàng)建一個新的數(shù)字”(新增),這樣的話,“自增操作符”(increment operator)就名不副實了。
Python 在理論上可以實現(xiàn) i++ 操作,但它就必須重新定義“自增操作符”,還會令有其它語言經(jīng)驗的人產(chǎn)生誤解,不如就讓大家直接寫成i += 1或者 i = i + 1好了。
C/C++ 等語言設計出 i++,最主要的目的是為了方便使用三段式的 for 結構:
for(int i = 0; i < 100; i++){ // 執(zhí)行 xxx }
這種程序關心的是數(shù)字本身的自增過程,數(shù)字做加法與程序體的執(zhí)行相關聯(lián)。
Python 中沒有這種 for 結構的寫法,它提供了更為優(yōu)雅的方式:
for i in range(100): # 執(zhí)行 xxx my_list = ["你好", "我是Python貓", "歡迎關注"] for info in my_list: print(info)
這里體現(xiàn)了不同的思維方式,它關心的是在一個數(shù)值范圍內(nèi)的迭代遍歷,并不關心也不需要人為對數(shù)字做加法。
Python 中的可迭代對象/迭代器/生成器提供了非常良好的迭代/遍歷用法,能夠做到對 i++ 的完全替代。
例如,上例中實現(xiàn)了對列表內(nèi)值的遍歷,Python 還可以用 enumerate() 實現(xiàn)對下標與具體值的同時遍歷:
my_list = ["你好", "我是Python貓", "歡迎關注"] for i, info in enumerate(my_list): print(i, info) # 打印結果: 0 你好 1 我是Python貓 2 歡迎關注
再例如對于字典的遍歷,Python 提供了 keys()、values()、items() 等遍歷方法,非常好用:
my_dict = {'a': '1', 'b': '2', 'c': '3'} for key in my_dict.keys(): print(key) for key, value in my_dict.items(): print(key, value)
有了這樣的利器,哪里還有 i++ 的用武之地呢?
不僅如此,Python 中基本上很少使用i += 1或者 i = i + 1,由于存在著隨處可見的可迭代對象,開發(fā)者們很容易實現(xiàn)對一個數(shù)值區(qū)間的操作,也就很少有對于某個數(shù)值作累加的訴求了。
所以,回到我們開頭的問題,其實這兩種“自增”寫法并沒有勝出 i++ 多少,只因為它們是通用型操作,又不需要引入新的操作符,所以 Python 才延續(xù)了一種基礎性的支持。真正的贏家其實是各種各樣的可迭代對象!
稍微小結下:Python 不支持自增操作符,一方面是因為它的整數(shù)是不可變類型的一等公民,自增操作(++)若要支持,則會帶來歧義;另一方面主要因為它有更合適的實現(xiàn),即可迭代對象,對遍歷操作有很好的支持。
數(shù)據(jù)分析咨詢請掃描二維碼
若不方便掃碼,搜微信號:CDAshujufenxi
SQL Server 中 CONVERT 函數(shù)的日期轉換:從基礎用法到實戰(zhàn)優(yōu)化 在 SQL Server 的數(shù)據(jù)處理中,日期格式轉換是高頻需求 —— 無論 ...
2025-09-18MySQL 大表拆分與關聯(lián)查詢效率:打破 “拆分必慢” 的認知誤區(qū) 在 MySQL 數(shù)據(jù)庫管理中,“大表” 始終是性能優(yōu)化繞不開的話題。 ...
2025-09-18CDA 數(shù)據(jù)分析師:表結構數(shù)據(jù) “獲取 - 加工 - 使用” 全流程的賦能者 表結構數(shù)據(jù)(如數(shù)據(jù)庫表、Excel 表、CSV 文件)是企業(yè)數(shù)字 ...
2025-09-18DSGE 模型中的 Et:理性預期算子的內(nèi)涵、作用與應用解析 動態(tài)隨機一般均衡(Dynamic Stochastic General Equilibrium, DSGE)模 ...
2025-09-17Python 提取 TIF 中地名的完整指南 一、先明確:TIF 中的地名有哪兩種存在形式? 在開始提取前,需先判斷 TIF 文件的類型 —— ...
2025-09-17CDA 數(shù)據(jù)分析師:解鎖表結構數(shù)據(jù)特征價值的專業(yè)核心 表結構數(shù)據(jù)(以 “行 - 列” 規(guī)范存儲的結構化數(shù)據(jù),如數(shù)據(jù)庫表、Excel 表、 ...
2025-09-17Excel 導入數(shù)據(jù)含缺失值?詳解 dropna 函數(shù)的功能與實戰(zhàn)應用 在用 Python(如 pandas 庫)處理 Excel 數(shù)據(jù)時,“缺失值” 是高頻 ...
2025-09-16深入解析卡方檢驗與 t 檢驗:差異、適用場景與實踐應用 在數(shù)據(jù)分析與統(tǒng)計學領域,假設檢驗是驗證研究假設、判斷數(shù)據(jù)差異是否 “ ...
2025-09-16CDA 數(shù)據(jù)分析師:掌控表格結構數(shù)據(jù)全功能周期的專業(yè)操盤手 表格結構數(shù)據(jù)(以 “行 - 列” 存儲的結構化數(shù)據(jù),如 Excel 表、數(shù)據(jù) ...
2025-09-16MySQL 執(zhí)行計劃中 rows 數(shù)量的準確性解析:原理、影響因素與優(yōu)化 在 MySQL SQL 調優(yōu)中,EXPLAIN執(zhí)行計劃是核心工具,而其中的row ...
2025-09-15解析 Python 中 Response 對象的 text 與 content:區(qū)別、場景與實踐指南 在 Python 進行 HTTP 網(wǎng)絡請求開發(fā)時(如使用requests ...
2025-09-15CDA 數(shù)據(jù)分析師:激活表格結構數(shù)據(jù)價值的核心操盤手 表格結構數(shù)據(jù)(如 Excel 表格、數(shù)據(jù)庫表)是企業(yè)最基礎、最核心的數(shù)據(jù)形態(tài) ...
2025-09-15Python HTTP 請求工具對比:urllib.request 與 requests 的核心差異與選擇指南 在 Python 處理 HTTP 請求(如接口調用、數(shù)據(jù)爬取 ...
2025-09-12解決 pd.read_csv 讀取長浮點數(shù)據(jù)的科學計數(shù)法問題 為幫助 Python 數(shù)據(jù)從業(yè)者解決pd.read_csv讀取長浮點數(shù)據(jù)時的科學計數(shù)法問題 ...
2025-09-12CDA 數(shù)據(jù)分析師:業(yè)務數(shù)據(jù)分析步驟的落地者與價值優(yōu)化者 業(yè)務數(shù)據(jù)分析是企業(yè)解決日常運營問題、提升執(zhí)行效率的核心手段,其價值 ...
2025-09-12用 SQL 驗證業(yè)務邏輯:從規(guī)則拆解到數(shù)據(jù)把關的實戰(zhàn)指南 在業(yè)務系統(tǒng)落地過程中,“業(yè)務邏輯” 是連接 “需求設計” 與 “用戶體驗 ...
2025-09-11塔吉特百貨孕婦營銷案例:數(shù)據(jù)驅動下的精準零售革命與啟示 在零售行業(yè) “流量紅利見頂” 的當下,精準營銷成為企業(yè)突圍的核心方 ...
2025-09-11CDA 數(shù)據(jù)分析師與戰(zhàn)略 / 業(yè)務數(shù)據(jù)分析:概念辨析與協(xié)同價值 在數(shù)據(jù)驅動決策的體系中,“戰(zhàn)略數(shù)據(jù)分析”“業(yè)務數(shù)據(jù)分析” 是企業(yè) ...
2025-09-11Excel 數(shù)據(jù)聚類分析:從操作實踐到業(yè)務價值挖掘 在數(shù)據(jù)分析場景中,聚類分析作為 “無監(jiān)督分組” 的核心工具,能從雜亂數(shù)據(jù)中挖 ...
2025-09-10統(tǒng)計模型的核心目的:從數(shù)據(jù)解讀到?jīng)Q策支撐的價值導向 統(tǒng)計模型作為數(shù)據(jù)分析的核心工具,并非簡單的 “公式堆砌”,而是圍繞特定 ...
2025-09-10