好程序员Python培训分享Traceback具体使用方法

本文介绍了Python中处理异常栈的traceback模块,包括print_exception、format_exception和extract_tb等工具函数的使用,以及sys.exc_info()的获取方式。通过示例展示了如何利用这些工具进行异常调试,并提及了cgitb模块在开发过程中的便利性,以及使用logging模块记录异常的正确方式。
摘要由CSDN通过智能技术生成

好程序员Python培训分享Traceback具体使用方法详解,首先在之前做Java的时候,异常对象默认就包含stacktrace相关的信息,通过异常对象的相关方法printStackTrace()和getStackTrace()等方法就可以取到异常栈信息,能打印到log辅助调试或者做一些别的事情。但是到了Python,在2.x中,异常对象可以是任何对象,经常看到很多代码是直接raise一个字符串出来,因此就不能像Java那样方便的获取异常栈了,因为异常对象和异常栈是分开的。而多数Python语言的书籍上重点在于描述Python中如何构造异常对象和raisetryexceptfinally这些的使用,对调试程序起关键作用的stacktrace往往基本上不怎么涉及。
  python中用于处理异常栈的模块是traceback模块,它提供了print_exception、format_exception等输出异常栈等常用的工具函数。

def func(a, b):
return a / b
if name == ‘main’:
import sys
import traceback
try:
func(1, 0)
except Exception as e:
print “print exc”
traceback.print_exc(file=sys.stdout)

输出结果:

print exc
Traceback (most recent call last):
File “./teststacktrace.py”, line 7, in
func(1, 0)
File “./teststacktrace.py”, line 2, in func
return a / b

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值