国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

python traceback捕獲并打印異常的方法

2020-02-15 22:18:22
字體:
來源:轉載
供稿:網友

異常處理是日常操作了,但是有時候不能只能打印我們處理的結果,還需要將我們的異常打印出來,這樣更直觀的顯示錯誤

下面來介紹traceback模塊來進行處理

  try:    1/0  except Exception, e:    print e

輸出結果是integer division or modulo by zero,只知道是報了這個錯,但是卻不知道在哪個文件哪個函數哪一行報的錯。

使用traceback

  try:    1/0  except Exception, e:    traceback.print_exc()

輸出結果

Traceback (most recent call last):

        File "test_traceback.py", line 3, in <module>

           1/0

ZeroDivisionError: integer division or modulo by zero

這樣非常直觀有利于調試。

 traceback.print_exc()跟traceback.format_exc()有什么區別呢?

format_exc()返回字符串,print_exc()則直接給打印出來。

即traceback.print_exc()與print traceback.format_exc()效果是一樣的。

print_exc()還可以接受file參數直接寫入到一個文件。比如

traceback.print_exc(file=open('tb.txt','w+'))

寫入到tb.txt文件去。

示例

# -*- coding:utf-8 -*-import osimport loggingimport traceback#設置log, 這里使用默認loglogging.basicConfig(    level=logging.INFO,    format='%(asctime)s %(filename)s[line:%(lineno)d] %(levelname)s %(message)s',    datefmt='[%Y-%m_%d %H:%M:%S]',    filename=os.path.dirname(os.path.realpath(__file__)) + "/" + 'test.log',    filemode='a')a=10b=0 #設置為0, 走異常流程; 否則, 走正常流程try:  res=a/b  logging.info("exec success, res:" + str(res))except Exception,e:  #format_exc()返回字符串,print_exc()則直接給打印出來  traceback.print_exc()  logging.warning("exec failed, failed msg:" + traceback.format_exc())

logging默認打印級別是warning.

日志打印:

[2017-11_17 07:51:02] trace.py[line:24] WARNING exec failed, failed msg:Traceback (most recent call last):

  File "trace.py", line 19, in <module>

    res=a/b

ZeroDivisionError: integer division or modulo by zero

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林站長站。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 湘西| 保亭| 象州县| 满洲里市| 来安县| 商都县| 淮阳县| 凤阳县| 平阳县| 黄骅市| 汪清县| 龙江县| 五河县| 忻城县| 乌兰察布市| 西吉县| 广河县| 广西| 临澧县| 万载县| 墨江| 平邑县| 元江| 舒兰市| 诸城市| 仁寿县| 绥中县| 岐山县| 绩溪县| 常州市| 福州市| 台东市| 故城县| 辽中县| 甘孜| 日照市| 越西县| 扬中市| 瓮安县| 乌拉特中旗| 奈曼旗|