最近在Python3环境中使用Flask,写代码的过程中,遇到一个捕获异常的代码
|
|
代码类似如上,其实就是需要捕获一个文件打开的异常,但是我想要获取这个异常的详细信息,但是在Python3下面运行报出了语法异常
|
|
但是代码改为下面的形式就会发现,异常能够正常捕获,并能够输出正常的异常详细信息
|
|
就可以正常捕获到详细的输出
|
|
查了下文档原来
|
|
是在Python 2.x的版本中使用
|
|
是在Python 3.x的版本中使用
其他获取异常详细信息的方式
1、 sys.exc_info() 和 sys.last_traceback
sys.last_traceback 包含的内容与 sys.exc_info() 相同,但它主要用于调试,并不总是被定义
sys.exc_info() 会返回一个3值元表,其中包含调用该命令时捕获的异常。 这个元表的内容为 (type, value, traceback) ,其中:
- type 从获取到的异常中得到类型名称,它是BaseException 的子类;
- value 是捕获到的异常实例;
- traceback 是一个 traceback 对象。
示例如下
|
|
关于sys.last_traceback,这里有其具体的使用方式 https://www.programcreek.com/python/example/3893/sys.last_traceback
2、使用 traceback trackback 模块用来精确模仿 python3 解析器的 stack trace 行为。在程序中应该尽量使用这个模块。 traceback.print_exc() 可以直接打印当前的异常。
|
|
traceback.print_tb() 用来打印上面提到的 trackback 对象。
|
|
traceback.print_exception() 可以直接打印 sys.exc_info() 提供的元表。
|
|
具体文档可以参考这里: https://docs.python.org/3/library/traceback.html?highlight=print_tb#module-traceback