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文件里

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

ftzchina

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值