基于python traceback實(shí)現(xiàn)異常的獲取與處理
這篇文章主要介紹了基于python traceback實(shí)現(xiàn)異常的獲取與處理,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
1、traceback.print_exc()
2、traceback.format_exc()
3、traceback.print_exception()
簡單說下這三個方法是做什么用的:
1、print_exc():是對異常棧輸出
2、format_exc():是把異常棧以字符串的形式返回,print(traceback.format_exc()) 就相當(dāng)于traceback.print_exc()
3、print_exception():traceback.print_exc()實(shí)現(xiàn)方式就是traceback.print_exception(sys.exc_info()),可以點(diǎn)sys.exc_info()進(jìn)
去看看實(shí)現(xiàn)
測試代碼如下:
def func(a, b):
return a / b
if __name__ == '__main__':
import sys
import time
import traceback
try:
func(1, 0)
except Exception as e:
print('***', type(e), e, '***')
time.sleep(2)
print("***traceback.print_exc():*** ")
time.sleep(1)
traceback.print_exc()
time.sleep(2)
print("***traceback.format_exc():*** ")
time.sleep(1)
print(traceback.format_exc())
time.sleep(2)
print("***traceback.print_exception():*** ")
time.sleep(1)
traceback.print_exception(*sys.exc_info())
運(yùn)行結(jié)果:
*** <class 'ZeroDivisionError'> division by zero *** ***traceback.print_exc():*** Traceback (most recent call last): File "E:/HttpRunnerManager-jh/ApiManager/tests.py", line 42, in <module> func(1, 0) File "E:/HttpRunnerManager-jh/ApiManager/tests.py", line 33, in func return a / b ZeroDivisionError: division by zero ***traceback.format_exc():*** Traceback (most recent call last): File "E:/HttpRunnerManager-jh/ApiManager/tests.py", line 42, in <module> func(1, 0) File "E:/HttpRunnerManager-jh/ApiManager/tests.py", line 33, in func return a / b ZeroDivisionError: division by zero ***traceback.print_exception():*** Traceback (most recent call last): File "E:/HttpRunnerManager-jh/ApiManager/tests.py", line 42, in <module> func(1, 0) File "E:/HttpRunnerManager-jh/ApiManager/tests.py", line 33, in func return a / b ZeroDivisionError: division by zero
可以看出,三種方式打印結(jié)果是一樣的。在開發(fā)時,做調(diào)試是很方便的。也可以把這種異常棧寫入日志。
logging.exception(ex) # 指名輸出棧蹤跡, logging.exception的內(nèi)部也是包了一層此做法 logging.error(ex, exc_info=1) # 更加嚴(yán)重的錯誤級別 logging.critical(ex, exc_info=1) # 我直接copy的,未嘗試。有時間會試下的
python 還有一個模塊叫cgitb,輸出的error非常詳情。
try:
func(1, 0)
except Exception as e:
import cgitb
cgitb.enable(format='text')
func(1, 0)
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- Python traceback模塊獲取異常信息的使用
- 解決python問題 Traceback (most recent call last)
- python如何利用traceback獲取詳細(xì)的異常信息
- Python基于traceback模塊獲取異常信息
- 淺談python出錯時traceback的解讀
- Python 輸出詳細(xì)的異常信息(traceback)方式
- python3 使用traceback定位異常實(shí)例
- Python異常模塊traceback用法實(shí)例分析
- 搞清楚 Python traceback的具體使用方法
- Python中使用logging和traceback模塊記錄日志和跟蹤異常
- 淺談Python traceback的優(yōu)雅處理
- python traceback捕獲并打印異常的方法
- Python?Traceback(most?recent?call?last)報(bào)錯信息:示例解讀
相關(guān)文章
解決pycharm無法識別本地site-packages的問題
今天小編就為大家分享一篇解決pycharm無法識別本地site-packages的問題,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-10-10
windows中python實(shí)現(xiàn)自動化部署
本文主要介紹了windows中python實(shí)現(xiàn)自動化部署,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-08-08
pandas 數(shù)據(jù)實(shí)現(xiàn)行間計(jì)算的方法
今天小編就為大家分享一篇pandas 數(shù)據(jù)實(shí)現(xiàn)行間計(jì)算的方法,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-06-06
python端口掃描系統(tǒng)實(shí)現(xiàn)方法
這篇文章主要介紹了python端口掃描系統(tǒng)實(shí)現(xiàn)方法,可實(shí)現(xiàn)簡單的外網(wǎng)IP掃描及寫入MySQL數(shù)據(jù)庫等功能,需要的朋友可以參考下2014-11-11
Python實(shí)現(xiàn)Wordcloud生成詞云圖的示例
這篇文章主要介紹了Python實(shí)現(xiàn)Wordcloud生成詞云圖的示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-03-03

