每天努力一点点,坚持下去 ------ 博客首页

Python之traceback模块跟踪异常【转】

python编写脚本异常处理时为什么推荐加上traceback,因为他可优雅的输出打印出程序当前具体的异常信息,方便定位问题,而单纯的打印异常所能提供的信息会非常的有限,一般的打印异常只有很少量的信息(通常是异常的value值),也就很难定位在哪块代码出的问题,以及如何出现这种异常!

  • traceback模块常用的函数是:

traceback.format_exc()#以字符串返回异常信息
traceback.print_exc()#直接打印出异常信息
traceback.print_exc()和traceback.format_exc()#输出的错误信息是一模一样的。
traceback.print_exc()#可以填入file参数,把异常信息填入到指定的file里。

简单示例:

复制代码
import traceback
try:
    1/0
except Exception as e:
    print(e)
    traceback.print_exc()


#结果:
division by zero  #这是普通打印print,仅有一行无具体报哪一行错误
#与下面对比,答案已经很明显了
Traceback (most recent call last):
  File "/Users/zouwenhong/Downloads/python_auto/test_api.py", line 144, in <module>
    1/0
ZeroDivisionError: division by zero
复制代码

 

posted @   他还在坚持嘛  阅读(202)  评论(0编辑  收藏  举报
编辑推荐:
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
阅读排行:
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
· 周边上新:园子的第一款马克杯温暖上架
点击右上角即可分享
微信分享提示