Python用try-except的时候获取错误行信息和文件信息

相信写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文件里

你可能感兴趣的:(Python,python,try-except)