这篇文章给大家分享的是有关python中缩进的案例分析的内容。小编觉得挺实用的,因此分享给大家做个参考。一起跟随小编过来看看吧。
python中的缩进(压痕)决定了代码的作用域范围。这一点和传统的c/c++有很大的不同(传统的c/c++使用花括号花括号{}符决定作用域的范围,python使用缩进空格来表示作用域的范围,相同缩进行的代码是处于同一范围)。
每行代码中开头的空格数(空格)用于计算该行代码的缩进级别(缩进级别),注意一个选项卡会被替换为1 ~ 8个空间(具体的空格数量,不同的编译器有不同的数量),缩进级别为0表示无缩进空格。
在一个源文件不建议同时使用空格和制表缩进符,当使用别人代码的时候几乎是不可能知道别人使用的是空格还是制表符,这时最好统一缩进,在艾德尔编辑器中可以使用编辑在Untabify地区将任何制表符转化为空格。
Python中的每一条语句都有一个缩进级别,并且缩进级别会使用栈的数据结构进行存储。在开始读取文件之前,0(表示缩进级别为0,无缩进)会被首先压入栈中,然后从文件开头到末尾,依次读取每行逻辑代码,每行逻辑代码的缩进级别都会和栈顶值进行比较,如果相等,那么什么都不会发生,如果比栈顶值大的话,那么该行逻辑代码的缩进级别就会被压入栈中,同时会生成一个缩进标记(缩进标记);如果比栈顶值小的话,那么栈中所有比该行逻辑代码缩进级别大的值都会从栈中移除,并且还会生成一个扩展标记(取消缩进标记)。
下面是一个正确的缩进案例:
def 烫发(左):# 0 ,,,,,,,#,Compute 从而list of all permutations of l ,,,if len (l), & lt;=1: #, 1 ,,,,,,,,,,,,,,,,,return [l] #, 2 ,,,r =[] #, 3 ,,,for 小姐:拷贝范围(len (l)): # 4 ,,,,,,,,,,,,s =, l(我),+,l (i + 1:) #, 5 ,,,,,,,,,,,,p =,烫(s) #, 6 ,,,,,,,,,,,,for x 拷贝p: #, 7 ,,,,,,,,,,,,,r.append (l(我+ 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 烫发(l):,,,,,,,,,,,,,,,,,,,,,,, # 1,错误:first line 缩进 ,,,for 小姐:拷贝范围(len (l)):,,,,,,,,,,,,, # 2,错误:not 缩进 ,,,,,,,s =, l(我),+,l (i + 1:) ,,,,,,,,,,,p =,烫(l[我],+,l [i + 1:]),,, # 3,错误:unexpected 缩进 ,,,,,,,,,,,for x p:拷贝 ,,,,,,,,,,,,,,,,,,,r.append (l(我+ 1),+,x) # 4 ,,,,,,,,,,,,,,,return r ,,,,,,,,,,,,,,, # 5,错误:,inconsistent 取消缩进
# 1、# 2和# 3处的错误解释的很清楚了。# 5的缩进级别在栈中找不到所以出错,# 5处的缩进级别是14日,比它的上面一行缩进级别18日,所以在# 5处应该进行出栈处理,但是在栈中找不到这14个级别,所以出错。
又比如:
if 正确的: ,,,印刷(“hello girl") 其他: ,,,印刷(“hello boy") ,打印(“以何种)
最后一行代码的缩进级别是1,而且比上一行代码的缩进级别小,所以应该出栈处理,但是在出站的时候找不到栈中以前有1的级别,所以报错。修改这个错误,只需要将最后一行的空格去掉就可以。