好程序员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