在實際調試程序的過程中,有時只獲得異常的類型是遠遠不夠的,還需要借助更詳細的異常信息才能解決問題。
捕獲異常時,有 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