【发布时间】:2011-05-14 02:11:37
【问题描述】:
我有一个可能引发异常的 python 函数。调用者捕获异常并处理它。现在我想为那个函数添加一个装饰器,也捕获异常,进行一些处理,然后重新引发异常以允许原始调用者处理它。这有效,除了当原始调用者显示异常的调用堆栈时,它显示装饰器中重新引发它的行,而不是最初发生的位置。示例代码:
import sys,traceback
def mydec(func):
def dec():
try:
func()
except Exception,e:
print 'Decorator handled exception %s' % e
raise e
return dec
@mydec
def myfunc():
x = 1/0
try:
myfunc()
except Exception,e:
print 'Exception: %s' % e
type,value,tb = sys.exc_info()
traceback.print_tb(tb)
输出是:
Decorator handled exception integer division or modulo by zero
Exception: integer division or modulo by zero
File "allbug.py", line 20, in <module>
myfunc()
File "allbug.py", line 9, in dec
raise e
我希望装饰器能够处理异常,但回溯应该指示x = 1/0 行而不是raise 行。我该怎么做?
【问题讨论】:
标签: python exception decorator