Python中的每一条语句都有一个缩进级别,并且缩进级别会使用栈的数据结构进行存储。在开始读取文件之前,0(表示缩进级别为0,无
缩进)会被首先压入栈中。然后从文件开头到末尾,依次读取每行逻辑代码,每行逻辑代码的缩进级别都会和栈顶值进行比较,如果相
等,那么什么都不会发生;如果比栈顶值大的话,那么该行逻辑代码的缩进级别就会被压入栈中,同时会生成一个缩进标记(INDENT
TOKEN);如果比栈顶值小的话,那么栈中所有比该行逻辑代码缩进级别大的值都会从栈中移除,并且还会生成一个扩展标记(DEDENT
TOKEN)。
推荐:Python教程
下面是一个正确的缩进案例:
defperm(l):#0 #Computethelistofallpermutationsofl iflen(l)<=1:#1 return[l]#2 r=[]#3 foriinrange(len(l)):#4 s=l[:i]+l[i+1:]#5 p=perm(s)#6 forxinp:#7 r.append(l[i:i+1]+x)#8 returnr#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。
下面是一个错误的案例
defperm(l):#1error:firstlineindented foriinrange(len(l)):#2error:notindented s=l[:i]+l[i+1:] p=perm(l[:i]+l[i+1:])#3error:unexpectedindent forxinp: r.append(l[i:i+1]+x)#4 returnr#5error:inconsistentdedent原文来自:https://www.py.cn
© 版权声明
文章版权归作者所有,未经允许请勿转载。
THE END
暂无评论内容