基于python traceback實(shí)現(xiàn)異常的獲取與處理
這篇文章主要介紹了基于python traceback實(shí)現(xiàn)異常的獲取與處理,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
1、traceback.print_exc()
2、traceback.format_exc()
3、traceback.print_exception()
簡(jiǎn)單說(shuō)下這三個(gè)方法是做什么用的:
1、print_exc():是對(duì)異常棧輸出
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)
測(cè)試代碼如下:
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é)果是一樣的。在開(kāi)發(fā)時(shí),做調(diào)試是很方便的。也可以把這種異常棧寫(xiě)入日志。
logging.exception(ex) # 指名輸出棧蹤跡, logging.exception的內(nèi)部也是包了一層此做法 logging.error(ex, exc_info=1) # 更加嚴(yán)重的錯(cuò)誤級(jí)別 logging.critical(ex, exc_info=1) # 我直接copy的,未嘗試。有時(shí)間會(huì)試下的
python 還有一個(gè)模塊叫cgitb,輸出的error非常詳情。
try: func(1, 0) except Exception as e: import cgitb cgitb.enable(format='text') func(1, 0)
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- Python traceback模塊獲取異常信息的使用
- 解決python問(wèn)題 Traceback (most recent call last)
- python如何利用traceback獲取詳細(xì)的異常信息
- Python基于traceback模塊獲取異常信息
- 淺談python出錯(cuò)時(shí)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)錯(cuò)信息:示例解讀
相關(guān)文章
解決pycharm無(wú)法識(shí)別本地site-packages的問(wèn)題
今天小編就為大家分享一篇解決pycharm無(wú)法識(shí)別本地site-packages的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-10-10windows中python實(shí)現(xiàn)自動(dòng)化部署
本文主要介紹了windows中python實(shí)現(xiàn)自動(dòng)化部署,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-08-08pandas 數(shù)據(jù)實(shí)現(xiàn)行間計(jì)算的方法
今天小編就為大家分享一篇pandas 數(shù)據(jù)實(shí)現(xiàn)行間計(jì)算的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-06-06python端口掃描系統(tǒng)實(shí)現(xiàn)方法
這篇文章主要介紹了python端口掃描系統(tǒng)實(shí)現(xiàn)方法,可實(shí)現(xiàn)簡(jiǎn)單的外網(wǎng)IP掃描及寫(xiě)入MySQL數(shù)據(jù)庫(kù)等功能,需要的朋友可以參考下2014-11-11Python實(shí)現(xiàn)Wordcloud生成詞云圖的示例
這篇文章主要介紹了Python實(shí)現(xiàn)Wordcloud生成詞云圖的示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-03-03