成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

您的位置:首頁技術(shù)文章
文章詳情頁

Python使用sys.exc_info()方法獲取異常信息

瀏覽:21日期:2022-07-16 14:54:41

在實際調(diào)試程序的過程中,有時只獲得異常的類型是遠(yuǎn)遠(yuǎn)不夠的,還需要借助更詳細(xì)的異常信息才能解決問題。

捕獲異常時,有 2 種方式可獲得更多的異常信息,分別是:

使用 sys 模塊中的 exc_info 方法; 使用 traceback 模塊中的相關(guān)函數(shù)。

本節(jié)首先介紹如何使用 sys 模塊中的 exc_info() 方法獲得更多的異常信息。

有關(guān) sys 模塊更詳細(xì)的介紹,可閱讀《Python sys模塊》。

模塊 sys 中,有兩個方法可以返回異常的全部信息,分別是 exc_info() 和 last_traceback(),這兩個函數(shù)有相同的功能和用法,本節(jié)僅以 exc_info() 方法為例。

exc_info() 方法會將當(dāng)前的異常信息以元組的形式返回,該元組中包含 3 個元素,分別為 type、value 和 traceback,它們的含義分別是:

type:異常類型的名稱,它是 BaseException 的子類(有關(guān) Python 異常類,可閱讀《Python常見異常類型》一節(jié)) value:捕獲到的異常實例。 traceback:是一個 traceback 對象

代碼示例:

使用 sys 模塊之前,需使用 import 引入import systry: x = int(input('請輸入一個被除數(shù):')) print('30除以',x,'等于',30/x)except: print(sys.exc_info()) print('其他異常...')

當(dāng)輸入 0 時,程序運行結(jié)果為:

請輸入一個被除數(shù):0(<class ’ZeroDivisionError’>, ZeroDivisionError(’division by zero’,), <traceback object at 0x000001FCF638DD48>)其他異常...

輸出結(jié)果中,第 2 行是拋出異常的全部信息,這是一個元組,有 3 個元素,第一個元素是一個 ZeroDivisionError 類;第 2 個元素是異常類型 ZeroDivisionError 類的一個實例;第 3 個元素為一個 traceback 對象。其中,通過前 2 個元素可以看出拋出的異常類型以及描述信息,對于第 3 個元素,是一個 traceback 對象,無法直接看出有關(guān)異常的信息,還需要對其做進一步處理。

要查看 traceback 對象包含的內(nèi)容,需要先引進 traceback 模塊,然后調(diào)用 traceback 模塊中的 print_tb 方法,并將 sys.exc_info() 輸出的 traceback 對象作為參數(shù)參入。例如:

#使用 sys 模塊之前,需使用 import 引入import sys#引入traceback模塊import tracebacktry: x = int(input('請輸入一個被除數(shù):')) print('30除以',x,'等于',30/x)except: #print(sys.exc_info()) traceback.print_tb(sys.exc_info()[2]) print('其他異常...')

輸入 0,程序運行結(jié)果為:

請輸入一個被除數(shù):0File 'C:UsersmengmaDesktopdemo.py', line 7, in <module>print('30除以',x,'等于',30/x)其他異常...

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

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: Python 編程
相關(guān)文章: