python什麼時候縮排

wangsys發表於2021-09-11

python什麼時候縮排

Python中的縮排(Indentation)決定了程式碼的作用域範圍。這一點和傳統的c/c++有很大的不同(傳統的c/c++使用花括號花括號{}符

決定作用域的範圍;python使用縮排空格來表示作用域的範圍,相同縮排行的程式碼是處於同一範圍)。

每行程式碼中開頭的空格數(whitespace)用於計算該行程式碼的縮排級別(Indentation level),注意一個Tab會被替換為1~8個

Space(具體的空格數量,不同的編譯器有不同的數量),縮排級別為0表示無縮排空格。

在一個原始檔不建議同時使用空格和製表縮排符,當使用別人程式碼的時候幾乎是不可能知道別人使用的是空格還是製表符,這時最好統一

縮排,在IDEL編輯器中可以使用 Edit > Untabify Region 將任何製表符轉化為空格。

Python中的每一條語句都有一個縮排級別,並且縮排級別會使用棧的資料結構進行儲存。在開始讀取檔案之前,0(表示縮排級別為0,無

縮排)會被首先壓入棧中。然後從檔案開頭到末尾,依次讀取每行邏輯程式碼,每行邏輯程式碼的縮排級別都會和棧頂值進行比較,如果相

等,那麼什麼都不會發生;如果比棧頂值大的話,那麼該行邏輯程式碼的縮排級別就會被壓入棧中,同時會生成一個縮排標記(INDENT 

TOKEN);如果比棧頂值小的話,那麼棧中所有比該行邏輯程式碼縮排級別大的值都會從棧中移除,並且還會生成一個擴充套件標記(DEDENT 

TOKEN)。

下面是一個正確的縮排案例:

def perm(l):#0
        # Compute the list of all permutations of l
    if len(l) <= 1:# 1
                  return [l]# 2
    r = []# 3
    for i in range(len(l)):# 4
             s = l[:i] + l[i+1:]# 5
             p = perm(s)# 6
             for x in p:# 7
              r.append(l[i:i+1] + x)# 8
    return r# 9

上面的#0行,縮排0個字元,由於檔案讀取之前0已經被壓入棧中了,所以棧中的資料不會發生改變。#1縮排4個字元,4被壓入棧中。#2

縮排18個字元,18被壓入棧中。#3縮排4個字元,18被彈出棧,棧頂值又為4了。#4和#3縮排一樣,所以不更新棧資料。#5縮排13個字

符,所以13被壓入棧中。#5、#6和#7的縮排一樣,不更新棧資料。#8縮排14個字元,14被壓入棧中。#9的縮排4個字元,所以棧中的

13和14都會彈出,棧頂值又恢復為4。

下面是一個錯誤的案例

    def perm(l):                       #1 error: first line indented
    for i in range(len(l)):             #2 error: not indented
        s = l[:i] + l[i+1:]
            p = perm(l[:i] + l[i+1:])   #3 error: unexpected indent
            for x in p:
                    r.append(l[i:i+1] + x)#4
                return r                #5 error: inconsistent dedent

#1、#2和#3處的錯誤解釋的很清楚了。#5的縮排級別在棧中找不到所以出錯,#5處的縮排級別是14,比它的上面一行縮排級別18,所以在

#5處應該進行出棧處理,但是在棧中找不到14這個級別,所以出錯。

又比如:

if True:    print("hello girl")else:    print("hello boy") print("end")

最後一行程式碼的縮排級別是1,而且比上一行程式碼的縮排級別小,所以應該出棧處理,但是在出站的時候找不到棧中以前有1的級別,所以

報錯。修改這個錯誤,只需要將最後一行的空格去掉就可以。

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/3244/viewspace-2835498/,如需轉載,請註明出處,否則將追究法律責任。

相關文章