如果错误没有被捕获,它就会一直往上抛,最后被Python解释器捕获,打印一个错误信息,然后程序退出。
来看看一个实例:
#!/usr/bin/env
def foo(s):
return 10 / int(s)
def bar(s):
return foo(s) * 2
def main():
bar('0')
main()
执行,结果如下:
Traceback (most recent call last):
File "D:/Python/test.py", line 11, in <module>
main()
File "D:/Python/test.py", line 9, in main
bar('0')
File "D:/Python/test.py", line 6, in bar
return foo(s) * 2
File "D:/Python/test.py", line 3, in foo
return 10 / int(s)
ZeroDivisionError: division by zero
出错并不可怕,可怕的是不知道哪里出错了。
解读错误信息是定位错误的关键。
我们从上往下可以看到整个错误的调用函数链:
错误信息第1
行:Traceback (most recent call last):
告诉我们这是错误的跟踪信息。
第2~3行:
File "D:/Python/test.py", line 11, in <module>
main()
调用main()
出错了,在代码文件test.py
的第11
行代码,但原因是第9
行:
File "D:/Python/test.py", line 9, in main
bar('0')
调用bar('0')
出错了,在代码文件test.py
的第9
行代码,但原因是第6
行:
File "D:/Python/test.py", line 6, in bar
return foo(s) * 2
原因是return foo(s) * 2
这个语句出错了,但这还不是最终原因,继续往下看:
File "D:/Python/test.py", line 3, in foo
return 10 / int(s)
原因是return 10 / int(s)
这个语句出错了,这是错误产生的源头,因为下面打印了:
ZeroDivisionError: division by zero
根据错误类型ZeroDivisionError
,我们判断,int(s)
本身并没有出错,但是int(s)
返回0
,在计算10 / 0
时出错,至此,找到错误源头。
出错的时候,一定要分析错误的调用栈信息,才能定位错误的位置。