在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,我都希望引发那些“真实的”(从我的应用程序的角度来看)异常-
在调试工具的原始位置关注。


问题答案:

做就是了:

raise

代替raise e。请参阅有关引发异常的教程部分,以及有关raise语句语言参考

如果不存在任何表达式,请raise重新引发当前作用域中活动的最后一个异常。如果当前范围内没有异常处于活动状态,则引发TypeError异常,表明这是一个错误(如果在IDLE下运行,则引发Queue.Empty异常)。