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

首頁 > 編程 > Python > 正文

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

2020-01-04 14:36:23
字體:
來源:轉載
供稿:網友

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

下面來介紹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

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


注:相關教程知識閱讀請移步到python教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 突泉县| 随州市| 安国市| 上高县| 平乐县| 武功县| 葫芦岛市| 三台县| 寻甸| 禄丰县| 桐梓县| 辽宁省| 麻栗坡县| 漾濞| 焦作市| 淮安市| 洪江市| 淮安市| 洛浦县| 屏边| 泾阳县| 页游| 淮南市| 专栏| 桓仁| 竹山县| 金沙县| 龙南县| 神农架林区| 凤山县| 镇坪县| 海口市| 新津县| 葫芦岛市| 五家渠市| 错那县| 花莲市| 巨鹿县| 宁武县| 根河市| 衢州市|