1. 程式人生 > 程式設計 >Python使用sys.exc_info()方法獲取異常資訊

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 物件

程式碼示例:

使用 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除以",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除以",30/x)
其他異常...

可以看到,輸出資訊中包含了更多的異常資訊,包括檔名、丟擲異常的程式碼所在的行數、丟擲異常的具體程式碼。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援我們。