zoukankan      html  css  js  c++  java
  • Python sys.exc_info()方法:获取异常信息

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

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

    1. 使用 sys 模块中的 exc_info 方法;
    2. 使用 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 对象

    代码示例:

    使用 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 对象作为参数参入。例如:

    #使用 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:UsersmengmaDesktopdemo.py", line 7, in <module>
        print("30除以",x,"等于",30/x)
    其他异常...

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

    print_tb 方法也仅是 traceback 模块众多方法中的一个,有关 traceback 模块如何获取更多异常信息,后续章节会做详细介绍。

  • 相关阅读:
    asp.net获取当前页面的url地址
    取多个name值相同的input里面的值
    多线程实践
    《谷物大脑》是骗子写的伪科学书:樊登著作4本,都是3星
    历史远未终结,全球化面临挑战:4星|《世界不是平的》
    大众汽车的恐吓文化导致了排放门:4星|《像职场赢家一样做减法》
    穿越回秦朝能发电吗?能:4星|《1分钟物理》
    作者没有实战经验,案例老旧,图表水平差:2星|《社群思维》
    滴滴优步面临各地竞争对手难以通吃:4星|《哈佛商业评论》第3期
    2星|《重新定义物流》:形式像PPT,内容像公关稿
  • 原文地址:https://www.cnblogs.com/bashliuhe/p/12749323.html
Copyright © 2011-2022 走看看