解決python的空格和tab混淆而報(bào)錯(cuò)的問題
在python里頭,空格和tab是區(qū)分開的,二者混在一起就會(huì)報(bào)錯(cuò),要么只用空格,要么只用tab
如果你用的是python的官方編譯器,通過以下方法可以直接將整個(gè)頁(yè)面的間隔符號(hào)統(tǒng)一:
1. 全選整個(gè)代碼(edit——select All)
2. 統(tǒng)一間隔符號(hào)為tab(format——tabify region),或者統(tǒng)一間隔符號(hào)為空格(format——untabify region)
補(bǔ)充:python 中縮進(jìn)—— tab 還是空格是不一樣的,一般不能混用,除非設(shè)置Tab自動(dòng)替換成空格
如下所示:
實(shí)驗(yàn)代碼:if 10>4: print(“hello”) print(“hello”) print(“hello”) 實(shí)驗(yàn)一 實(shí)驗(yàn)二 實(shí)驗(yàn)三 實(shí)驗(yàn)四 實(shí)驗(yàn)五 操作 每一行都用1個(gè) tab 鍵縮進(jìn) 第一行用1個(gè) tab,第二行用 2個(gè) tab, 第三行用1個(gè) tab 用空格鍵縮進(jìn),每一行都用1個(gè)空格。 第一行用1個(gè)空格,第二行用1個(gè)空格,第三行用2個(gè)空格 混合用tab和空格:第一行用1個(gè)tab(編輯器中設(shè)置一個(gè)tab的寬度是4個(gè)空格),第二行用1個(gè)tab,第三行用4個(gè)空格。 結(jié)果 沒有報(bào)錯(cuò) IndentationError: unexpected indent 沒有報(bào)錯(cuò) IndentationError: unexpected indent IndentationError: unindent does not match any outer indentation level 分析 我們看一下代碼的 ASCII,以確定用的確實(shí)是 tab 看一下 ASCII 碼,確定確實(shí)用了不同個(gè)數(shù)的 tab 看一下 ASCII 碼,確定我們用的是空格(ASCII 值是 0x20) 用空格縮進(jìn)是可以的,但是要保證每行用同樣個(gè)數(shù)的空格 。 看一下 ASCII 碼,就知道空格和 tab 混用了。空格和tab不能混用
實(shí)驗(yàn)6
混合用tab和空格:每一行都用4個(gè)空格 + 一個(gè)tab
哦,我想起來了,貼 ASCII 碼實(shí)在是麻煩,編輯器有一個(gè)顯示空格和制表符的功能。咱們顯示出來后貼個(gè)代碼截圖圖。
運(yùn)行結(jié)果
hello
hello
hello
雖然可以成功運(yùn)行,但這樣做就是“作”。
實(shí)驗(yàn)結(jié)論做了這么多實(shí)驗(yàn),終于可以得出結(jié)論了:
Python中縮進(jìn)可以用空格,也可以用tab,甚至可以混用(比如每一行你先用1個(gè)tab,再用4個(gè)空格,再用2個(gè)tab,再用4個(gè)空格);
不管你怎么縮進(jìn)的,你都要保證,第二行和第一行用的字符一樣,第三行和第二行用的字符一樣,…… ,也就是每一行用的字符一樣。
最佳實(shí)踐其實(shí) Python 并沒有強(qiáng)制要求你用Tab縮進(jìn)或者用空格縮進(jìn),但在 PEP8中,建議使用4個(gè)空格來縮進(jìn)。
Python Enhancement Proposals index 8 —— Style Guide for Python Code
https://www.python.org/dev/peps/pep-0008/
Use 4 spaces per indentation level.
notepad++ Tab自動(dòng)轉(zhuǎn)換成4個(gè)空格
對(duì)于 VIM,可以這樣設(shè)置
set tabstop=4 '設(shè)置Tab顯示的寬度為4個(gè)空格
set expandtab '設(shè)置將Tab自動(dòng)展開成為空格
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持好吧啦網(wǎng)。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。
相關(guān)文章:
1. WML的簡(jiǎn)單例子及編輯、測(cè)試方法第1/2頁(yè)2. 前端html+css實(shí)現(xiàn)動(dòng)態(tài)生日快樂代碼3. XML基本概念XPath、XSLT與XQuery函數(shù)介紹4. el-input無法輸入的問題和表單驗(yàn)證失敗問題解決5. 關(guān)于html嵌入xml數(shù)據(jù)島如何穿過樹形結(jié)構(gòu)關(guān)系的問題6. CSS3實(shí)例分享之多重背景的實(shí)現(xiàn)(Multiple backgrounds)7. 不要在HTML中濫用div8. vue實(shí)現(xiàn)復(fù)制文字復(fù)制圖片實(shí)例詳解9. XML入門的常見問題(三)10. XML入門的常見問題(四)
