我平常看错误只看最下面一行的‘错误’,这也只能调试比较低级且明显的错误。
python中所有的异常都是Exception的子类,看看python内建的exceptions:
方式一:捕获所有的异常:
''' 捕获异常的第一种方式,捕获所有的异常 '''
try:
a = b
b = c
except Exception,data:
print Exception,":",data
变量‘b’没有声明,看看输出
<type 'exceptions.Exception'> : name 'b' is not defined
像我这种菜鸟经常做菜鸟级别的错误。
方式二: 导入traceback模块,来跟踪错误信息。
import traceback
''' 捕获异常的第二种方式,使用traceback查看异常 '''
try:
a = b
b = c
except:
print traceback.print_exc()
先看看输出结果:
Traceback (most recent call last):
File "E:\python\33.py", line 4, in <module>
a = b
NameError: name 'b' is not defined
其中,traceback.print_exc()返回所有的异常,还有个traceback.format_exc()是返回字符串。
很明显,traceback跟踪了错误的信息所在的位置。
方式三:采用sys模块来捕获异常。
import sys
''' 捕获异常的第三种方式,使用sys模块捕获异常 '''
try:
a = b
b = c
except:
info = sys.exc_info()
print info
print info[0]
print info[1]
查了一下,sys.exc_info()是获取当前的异常信息。
看看结果:
(<type 'exceptions.NameError'>, NameError("name 'b' is not defined",), <traceback object at 0x02139E68>)
<type 'exceptions.NameError'>
name 'b' is not defined
还有个sys.exc_clear()是清除当前的异常信息。
还可以自己触发异常,用raise.
try:
raise ValueError#自己抛出一个异常
except ValueError:
print 'a error'
输出:
a error