
文章來(lái)源: Python貓
作者:豌豆花下貓
在 C/C++/Java 等等語(yǔ)言中,整型變量的自增或自減操作是標(biāo)配,它們又可分為前綴操作(++i 和 --i)與后綴操作(i++ 和 i--),彼此存在著一些細(xì)微差別,各有不同的用途。
這些語(yǔ)言的使用者在接觸 Python 時(shí),可能會(huì)疑惑為什么它不提供 ++ 或 -- 的操作呢?在我前不久發(fā)的《Python的十萬(wàn)個(gè)為什么?》里,就有不少同學(xué)在調(diào)查問(wèn)卷中表示了對(duì)此話題感興趣。
Python 中雖然可能出現(xiàn) ++i 這種前綴形式的寫(xiě)法,但是它并沒(méi)有“++”自增操作符,此處只是兩個(gè)“+”(正數(shù)符號(hào))的疊加而已,至于后綴形式的“++”,則完全不支持(SyntaxError: invalid syntax)。
本期“Python為什么”欄目,我們將會(huì)從兩個(gè)主要的角度來(lái)回答:Python 為什么不支持 i++ 自增語(yǔ)法?(PS:此處自增指代“自增和自減”,下同)
首先,Python 當(dāng)然可以實(shí)現(xiàn)自增效果,即寫(xiě)成i+=1或者i=i+1,這在其它語(yǔ)言中也是通用的。
雖然 Python 在底層用了不同的魔術(shù)方法(__add__()和__iadd__())來(lái)完成計(jì)算,但表面上的效果完全相同。
所以,我們的問(wèn)題可以轉(zhuǎn)化成:為什么上面的兩種寫(xiě)法會(huì)勝過(guò) i++,成為 Python 的最終選擇呢?
當(dāng)我們定義i = 1000時(shí),不同語(yǔ)言會(huì)作出不同的處理:
所以當(dāng)我們令i“自增”時(shí)(i=i+1),它們的處理是不同的:
打一個(gè)不太恰當(dāng)?shù)谋确剑篊 中的 i 就像一個(gè)宿主,數(shù)字 1000 寄生在它上面;而 Python 中的 1000 像個(gè)宿主,名稱 i 寄生在它上面。C 中的 i 與 Python 中的 1000,它們則寄生在底層的內(nèi)存空間上……
還可以這樣理解:C 中的變量 i 是一等公民,數(shù)字 1000 是它的一個(gè)可變的屬性;Python 中的數(shù)字 1000 是一等公民,名稱 i 是它的一個(gè)可變的屬性。
有了以上的鋪墊,我們?cè)賮?lái)看看i++,不難發(fā)現(xiàn):
Python 若支持 i++,其操作過(guò)程要比 C 的 i++ 復(fù)雜,而且其含義也不再是“令數(shù)字增加1”(自增),而是“創(chuàng)建一個(gè)新的數(shù)字”(新增),這樣的話,“自增操作符”(increment operator)就名不副實(shí)了。
Python 在理論上可以實(shí)現(xiàn) i++ 操作,但它就必須重新定義“自增操作符”,還會(huì)令有其它語(yǔ)言經(jīng)驗(yàn)的人產(chǎn)生誤解,不如就讓大家直接寫(xiě)成i += 1或者 i = i + 1好了。
C/C++ 等語(yǔ)言設(shè)計(jì)出 i++,最主要的目的是為了方便使用三段式的 for 結(jié)構(gòu):
for(int i = 0; i < 100; i++){ // 執(zhí)行 xxx }
這種程序關(guān)心的是數(shù)字本身的自增過(guò)程,數(shù)字做加法與程序體的執(zhí)行相關(guān)聯(lián)。
Python 中沒(méi)有這種 for 結(jié)構(gòu)的寫(xiě)法,它提供了更為優(yōu)雅的方式:
for i in range(100): # 執(zhí)行 xxx my_list = ["你好", "我是Python貓", "歡迎關(guān)注"] for info in my_list: print(info)
這里體現(xiàn)了不同的思維方式,它關(guān)心的是在一個(gè)數(shù)值范圍內(nèi)的迭代遍歷,并不關(guān)心也不需要人為對(duì)數(shù)字做加法。
Python 中的可迭代對(duì)象/迭代器/生成器提供了非常良好的迭代/遍歷用法,能夠做到對(duì) i++ 的完全替代。
例如,上例中實(shí)現(xiàn)了對(duì)列表內(nèi)值的遍歷,Python 還可以用 enumerate() 實(shí)現(xiàn)對(duì)下標(biāo)與具體值的同時(shí)遍歷:
my_list = ["你好", "我是Python貓", "歡迎關(guān)注"] for i, info in enumerate(my_list): print(i, info) # 打印結(jié)果: 0 你好 1 我是Python貓 2 歡迎關(guān)注
再例如對(duì)于字典的遍歷,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,由于存在著隨處可見(jiàn)的可迭代對(duì)象,開(kāi)發(fā)者們很容易實(shí)現(xiàn)對(duì)一個(gè)數(shù)值區(qū)間的操作,也就很少有對(duì)于某個(gè)數(shù)值作累加的訴求了。
所以,回到我們開(kāi)頭的問(wèn)題,其實(shí)這兩種“自增”寫(xiě)法并沒(méi)有勝出 i++ 多少,只因?yàn)樗鼈兪峭ㄓ眯筒僮?,又不需要引入新的操作符,所?Python 才延續(xù)了一種基礎(chǔ)性的支持。真正的贏家其實(shí)是各種各樣的可迭代對(duì)象!
稍微小結(jié)下:Python 不支持自增操作符,一方面是因?yàn)樗恼麛?shù)是不可變類型的一等公民,自增操作(++)若要支持,則會(huì)帶來(lái)歧義;另一方面主要因?yàn)樗懈线m的實(shí)現(xiàn),即可迭代對(duì)象,對(duì)遍歷操作有很好的支持。
數(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)換是高頻需求 —— 無(wú)論 ...
2025-09-18MySQL 大表拆分與關(guān)聯(lián)查詢效率:打破 “拆分必慢” 的認(rèn)知誤區(qū) 在 MySQL 數(shù)據(jù)庫(kù)管理中,“大表” 始終是性能優(yōu)化繞不開(kāi)的話題。 ...
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 中的地名有哪兩種存在形式? 在開(kāi)始提取前,需先判斷 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è)操盤(pán)手 表格結(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)求開(kāi)發(fā)時(shí)(如使用requests ...
2025-09-15CDA 數(shù)據(jù)分析師:激活表格結(jié)構(gòu)數(shù)據(jù)價(jià)值的核心操盤(pán)手 表格結(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ù)法問(wèn)題 為幫助 Python 數(shù)據(jù)從業(yè)者解決pd.read_csv讀取長(zhǎng)浮點(diǎn)數(shù)據(jù)時(shí)的科學(xué)計(jì)數(shù)法問(wèn)題 ...
2025-09-12CDA 數(shù)據(jù)分析師:業(yè)務(wù)數(shù)據(jù)分析步驟的落地者與價(jià)值優(yōu)化者 業(yè)務(wù)數(shù)據(jù)分析是企業(yè)解決日常運(yùn)營(yíng)問(wèn)題、提升執(zhí)行效率的核心手段,其價(jià)值 ...
2025-09-12用 SQL 驗(yàn)證業(yè)務(wù)邏輯:從規(guī)則拆解到數(shù)據(jù)把關(guān)的實(shí)戰(zhàn)指南 在業(yè)務(wù)系統(tǒng)落地過(guò)程中,“業(yè)務(wù)邏輯” 是連接 “需求設(shè)計(jì)” 與 “用戶體驗(yàn) ...
2025-09-11塔吉特百貨孕婦營(yíng)銷案例:數(shù)據(jù)驅(qū)動(dòng)下的精準(zhǔn)零售革命與啟示 在零售行業(yè) “流量紅利見(jiàn)頂” 的當(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)景中,聚類分析作為 “無(wú)監(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