Python使用sys.exc_info()方法獲取異常信息
在實(shí)際調(diào)試程序的過程中,有時(shí)只獲得異常的類型是遠(yuǎn)遠(yuǎn)不夠的,還需要借助更詳細(xì)的異常信息才能解決問題。
捕獲異常時(shí),有 2 種方式可獲得更多的異常信息,分別是:
- 使用 sys 模塊中的 exc_info 方法;
- 使用 traceback 模塊中的相關(guān)函數(shù)。
本節(jié)首先介紹如何使用 sys 模塊中的 exc_info() 方法獲得更多的異常信息。
有關(guān) sys 模塊更詳細(xì)的介紹,可閱讀《Python sys模塊》。
模塊 sys 中,有兩個(gè)方法可以返回異常的全部信息,分別是 exc_info() 和 last_traceback(),這兩個(gè)函數(shù)有相同的功能和用法,本節(jié)僅以 exc_info() 方法為例。
exc_info() 方法會(huì)將當(dāng)前的異常信息以元組的形式返回,該元組中包含 3 個(gè)元素,分別為 type、value 和 traceback,它們的含義分別是:
- type:異常類型的名稱,它是 BaseException 的子類(有關(guān) Python 異常類,可閱讀《Python常見異常類型》一節(jié))
- value:捕獲到的異常實(shí)例。
- traceback:是一個(gè) traceback 對(duì)象
代碼示例:
使用 sys 模塊之前,需使用 import 引入 import sys try: x = int(input("請(qǐng)輸入一個(gè)被除數(shù):")) print("30除以",x,"等于",30/x) except: print(sys.exc_info()) print("其他異常...")
當(dāng)輸入 0 時(shí),程序運(yùn)行結(jié)果為:
請(qǐng)輸入一個(gè)被除數(shù):0
(<class 'ZeroDivisionError'>, ZeroDivisionError('division by zero',), <traceback object at 0x000001FCF638DD48>)
其他異常...
輸出結(jié)果中,第 2 行是拋出異常的全部信息,這是一個(gè)元組,有 3 個(gè)元素,第一個(gè)元素是一個(gè) ZeroDivisionError 類;第 2 個(gè)元素是異常類型 ZeroDivisionError 類的一個(gè)實(shí)例;第 3 個(gè)元素為一個(gè) traceback 對(duì)象。其中,通過前 2 個(gè)元素可以看出拋出的異常類型以及描述信息,對(duì)于第 3 個(gè)元素,是一個(gè) traceback 對(duì)象,無法直接看出有關(guān)異常的信息,還需要對(duì)其做進(jìn)一步處理。
要查看 traceback 對(duì)象包含的內(nèi)容,需要先引進(jìn) traceback 模塊,然后調(diào)用 traceback 模塊中的 print_tb 方法,并將 sys.exc_info() 輸出的 traceback 對(duì)象作為參數(shù)參入。例如:
#使用 sys 模塊之前,需使用 import 引入 import sys #引入traceback模塊 import traceback try: x = int(input("請(qǐng)輸入一個(gè)被除數(shù):")) print("30除以",x,"等于",30/x) except: #print(sys.exc_info()) traceback.print_tb(sys.exc_info()[2]) print("其他異常...")
輸入 0,程序運(yùn)行結(jié)果為:
請(qǐng)輸入一個(gè)被除數(shù):0
File "C:\Users\mengma\Desktop\demo.py", line 7, in <module>
print("30除以",x,"等于",30/x)
其他異常...
可以看到,輸出信息中包含了更多的異常信息,包括文件名、拋出異常的代碼所在的行數(shù)、拋出異常的具體代碼。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

flask/django 動(dòng)態(tài)查詢表結(jié)構(gòu)相同表名不同數(shù)據(jù)的Model實(shí)現(xiàn)方法

Python?numpy之線性代數(shù)與隨機(jī)漫步

Python 提取dict轉(zhuǎn)換為xml/json/table并輸出的實(shí)現(xiàn)代碼

python定時(shí)利用QQ郵件發(fā)送天氣預(yù)報(bào)的實(shí)例

Python?dataframe如何設(shè)置index

簡(jiǎn)單了解python中的f.b.u.r函數(shù)