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:\Users\mengma\Desktop\demo.py", line 7, in <module>
    print("30除以",x,"等於",30/x)
其他異常...

可以看到,輸出信息中包含了更多的異常信息,包括文件名、拋出異常的代碼所在的行數、拋出異常的具體代碼。

print_tb 方法也僅是 traceback 模塊眾多方法中的一個,有關 traceback 模塊如何獲取更多異常信息,后續章節會做詳細介紹。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM