在Python中,如何在维护原始调用堆栈的同时检查并重新引发异常?
问题内容:
我遇到一种情况,我正在捕获特定的异常类型,检查异常的消息以检查它是否确实是我要捕获的异常,然后重新引发该异常(如果不是):
try:
# do something exception-prone
except FooException as e:
if e.message == 'Something I want to handle':
# handle the exception
else:
raise e
这很好,但有一个问题。在我重新引发异常的情况下,该异常现在发生在我重新引发该异常的行(即raise e
),而不是在异常最初发生的位置。对于您想知道原始异常发生在哪里的调试来说,这不是理想的选择。
因此,我的问题是:在保持原始异常位置的同时,捕获异常之后,是否有任何方法可以重新引发或以其他方式“传递”异常?
注意:如果您想知道实际情况是什么:我正在使用动态导入一些模块__import__
。我正在ImportError
设法优雅地处理所有这些模块都不存在的情况。但是,如果这些模块中的任何一个本身包含import语句引发ImportError
,我都希望引发那些“真实的”(从我的应用程序的角度来看)异常-
在调试工具的原始位置关注。
问题答案: