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

1
2
3
4
5
6
7
8
9
10
11
12
13
14
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

1
print(str(e), flush=True)

Python try...except...时捕获异常时具体文件和行数
https://waym1ng.github.io/2021/07/08/Python try...except...时捕获异常时具体文件和行数/
作者
waymingz
发布于
2021年7月8日
许可协议