基于python traceback實現(xiàn)異常的獲取與處理
這篇文章主要介紹了基于python traceback實現(xiàn)異常的獲取與處理,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
1、traceback.print_exc()
2、traceback.format_exc()
3、traceback.print_exception()
簡單說下這三個方法是做什么用的:
1、print_exc():是對異常棧輸出
2、format_exc():是把異常棧以字符串的形式返回,print(traceback.format_exc()) 就相當于traceback.print_exc()
3、print_exception():traceback.print_exc()實現(xiàn)方式就是traceback.print_exception(sys.exc_info()),可以點sys.exc_info()進
去看看實現(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())
運行結果:
*** <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
可以看出,三種方式打印結果是一樣的。在開發(fā)時,做調試是很方便的。也可以把這種異常棧寫入日志。
logging.exception(ex) # 指名輸出棧蹤跡, logging.exception的內部也是包了一層此做法 logging.error(ex, exc_info=1) # 更加嚴重的錯誤級別 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)
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
- Python traceback模塊獲取異常信息的使用
- 解決python問題 Traceback (most recent call last)
- python如何利用traceback獲取詳細的異常信息
- Python基于traceback模塊獲取異常信息
- 淺談python出錯時traceback的解讀
- Python 輸出詳細的異常信息(traceback)方式
- python3 使用traceback定位異常實例
- Python異常模塊traceback用法實例分析
- 搞清楚 Python traceback的具體使用方法
- Python中使用logging和traceback模塊記錄日志和跟蹤異常
- 淺談Python traceback的優(yōu)雅處理
- python traceback捕獲并打印異常的方法
- Python?Traceback(most?recent?call?last)報錯信息:示例解讀
相關文章
解決pycharm無法識別本地site-packages的問題
今天小編就為大家分享一篇解決pycharm無法識別本地site-packages的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-10-10
pandas 數(shù)據(jù)實現(xiàn)行間計算的方法
今天小編就為大家分享一篇pandas 數(shù)據(jù)實現(xiàn)行間計算的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-06-06
Python實現(xiàn)Wordcloud生成詞云圖的示例
這篇文章主要介紹了Python實現(xiàn)Wordcloud生成詞云圖的示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-03-03

