gpt4 book ai didi

Python使用sys.exc_info()方法获取异常信息

转载 作者:qq735679552 更新时间:2022-09-29 22:32:09 25 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章Python使用sys.exc_info()方法获取异常信息由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

在实际调试程序的过程中,有时只获得异常的类型是远远不够的,还需要借助更详细的异常信息才能解决问题.

捕获异常时,有 2 种方式可获得更多的异常信息,分别是:

  • 使用 sys 模块中的 exc_info 方法;
  • 使用 traceback 模块中的相关函数。

本节首先介绍如何使用 sys 模块中的 exc_info() 方法获得更多的异常信息.

有关 sys 模块更详细的介绍,可阅读《Python sys模块》.

模块 sys 中,有两个方法可以返回异常的全部信息,分别是 exc_info() 和 last_traceback(),这两个函数有相同的功能和用法,本节仅以 exc_info() 方法为例.

exc_info() 方法会将当前的异常信息以元组的形式返回,该元组中包含 3 个元素,分别为 type、value 和 traceback,它们的含义分别是:

  • type:异常类型的名称,它是 BaseException 的子类(有关 Python 异常类,可阅读《Python常见异常类型》一节)
  • value:捕获到的异常实例。
  • traceback:是一个 traceback 对象

代码示例:

?
1
2
3
4
5
6
7
8
使用 sys 模块之前,需使用 import 引入
import sys
try :
  x = int ( input ( "请输入一个被除数:" ))
  print ( "30除以" ,x, "等于" , 30 / x)
except :
  print (sys.exc_info())
  print ( "其他异常..." )

当输入 0 时,程序运行结果为:

请输入一个被除数:0 (<class 'ZeroDivisionError'>, ZeroDivisionError('division by zero',), <traceback object at 0x000001FCF638DD48>) 其他异常... 。

输出结果中,第 2 行是抛出异常的全部信息,这是一个元组,有 3 个元素,第一个元素是一个 ZeroDivisionError 类;第 2 个元素是异常类型 ZeroDivisionError 类的一个实例;第 3 个元素为一个 traceback 对象。其中,通过前 2 个元素可以看出抛出的异常类型以及描述信息,对于第 3 个元素,是一个 traceback 对象,无法直接看出有关异常的信息,还需要对其做进一步处理.

要查看 traceback 对象包含的内容,需要先引进 traceback 模块,然后调用 traceback 模块中的 print_tb 方法,并将 sys.exc_info() 输出的 traceback 对象作为参数参入。例如:

?
1
2
3
4
5
6
7
8
9
10
11
#使用 sys 模块之前,需使用 import 引入
import sys
#引入traceback模块
import traceback
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", line 7, in <module> print("30除以",x,"等于",30/x) 其他异常... 。

可以看到,输出信息中包含了更多的异常信息,包括文件名、抛出异常的代码所在的行数、抛出异常的具体代码.

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我.

原文链接:https://www.cnblogs.com/bashliuhe/p/12749323.html 。

最后此篇关于Python使用sys.exc_info()方法获取异常信息的文章就讲到这里了,如果你想了解更多关于Python使用sys.exc_info()方法获取异常信息的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com