相信写Python的同学都用过try-except来捕捉程序的错误,防止程序崩溃,一般我们都是简单的使用下面的语句来捕捉错误并且打印错误信息
def testExcept():
try:
str1 = 'fei'
int1 = 5
result = str1 / int1
except Exception as e:
print(e)
testExcept()
运行结果如下:
unsupported operand type(s) for /: 'str' and 'int'
有时候在大的工程里或者复杂的程序里,仅仅打印e只能简单的显示出程序出错的信息,有时候我们仅仅根据这个信息很难定位到哪一行和哪个文件,这时候比较笨的调试方法就是去掉try-except再跑一次让程序崩溃显示出具体的信息。
比较快速便捷的定位错误信息就是定位到发生错误具体的行和文件,我们的错误对象e其实是有相关的属性的
def testExcept():
try:
str1 = 'fei'
int1 = 5
result = str1 / int1
except Exception as e:
print(e)
print(f'error file:{e.__traceback__.tb_frame.f_globals["__file__"]}')
print(f"error line:{e.__traceback__.tb_lineno}")
testExcept()
运行结果如下
unsupported operand type(s) for /: 'str' and 'int'
error file:C:\Users\exception.py
error line:7
[Finished in 0.4s]
可以看到定位到了发生错误的行是第7行,在exception.py文件里