Python使用sys.exc_info()方法获取异常信息
在实际调试程序的过程中,有时只获得异常的类型是远远不够的,还需要借助更详细的异常信息才能解决问题。
捕获异常时,有2种方式可获得更多的异常信息,分别是:
- 使用sys模块中的exc_info方法;
- 使用traceback模块中的相关函数。
本节首先介绍如何使用sys模块中的exc_info()方法获得更多的异常信息。
有关sys模块更详细的介绍,可阅读《Pythonsys模块》。
模块sys中,有两个方法可以返回异常的全部信息,分别是exc_info()和last_traceback(),这两个函数有相同的功能和用法,本节仅以exc_info()方法为例。
exc_info()方法会将当前的异常信息以元组的形式返回,该元组中包含3个元素,分别为type、value和traceback,它们的含义分别是:
- type:异常类型的名称,它是BaseException的子类(有关Python异常类,可阅读《Python常见异常类型》一节)
- value:捕获到的异常实例。
- traceback:是一个traceback对象
代码示例:
使用sys模块之前,需使用import引入 importsys try: x=int(input("请输入一个被除数:")) print("30除以",x,"等于",30/x) except: print(sys.exc_info()) print("其他异常...")
当输入0时,程序运行结果为:
请输入一个被除数:0
(,ZeroDivisionError('divisionbyzero',), )
其他异常...
输出结果中,第2行是抛出异常的全部信息,这是一个元组,有3个元素,第一个元素是一个ZeroDivisionError类;第2个元素是异常类型ZeroDivisionError类的一个实例;第3个元素为一个traceback对象。其中,通过前2个元素可以看出抛出的异常类型以及描述信息,对于第3个元素,是一个traceback对象,无法直接看出有关异常的信息,还需要对其做进一步处理。
要查看traceback对象包含的内容,需要先引进traceback模块,然后调用traceback模块中的print_tb方法,并将sys.exc_info()输出的traceback对象作为参数参入。例如:
#使用sys模块之前,需使用import引入 importsys #引入traceback模块 importtraceback try: x=int(input("请输入一个被除数:")) print("30除以",x,"等于",30/x) except: #print(sys.exc_info()) traceback.print_tb(sys.exc_info()[2]) print("其他异常...")
输入0,程序运行结果为:
请输入一个被除数:0
File"C:\Users\mengma\Desktop\demo.py",line7,in
print("30除以",x,"等于",30/x)
其他异常...
可以看到,输出信息中包含了更多的异常信息,包括文件名、抛出异常的代码所在的行数、抛出异常的具体代码。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。