Python try...except...时捕获异常时具体文件和行数

2021/7/8 20:09:37

本文主要是介绍Python try...except...时捕获异常时具体文件和行数,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

def try_exception_test():
    try:
        a = 0
        b = 1/a
        print(b)
    except Exception as e:
        print(e)
        # 发生异常所在的文件
        print(e.__traceback__.tb_frame.f_globals["__file__"])
        # 发生异常所在的行数
        print(e.__traceback__.tb_lineno)

if __name__ == '__main__':
    try_exception_test()

模拟一段会抛出异常的代码

执行结果:

division by zero
C:/Users/admin01/Desktop/script/demo.py
4

可以看到报错原因为division by zero

文件位置为C:/Users/admin01/Desktop/script/demo.py

行数为第4行

 要是系统中不能实时打印出来的话,可以考虑加上 flush=True

print(str(e), flush=True)



这篇关于Python try...except...时捕获异常时具体文件和行数的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!


扫一扫关注最新编程教程