61

在交互式提示符 (REPL) 下调试 Python 代码时,我通常会编写一些引发异常的代码,但我没有将其包装在try/except中,因此一旦引发错误,我就永远丢失了异常对象.

通常,Python 打印出来的回溯和错误消息是不够的。例如,在获取 URL 时,服务器可能会返回 40x 错误,并且您需要通过error.read()... 响应的内容,但您已经没有错误对象了。例如:

>>> import urllib2
>>> f = urllib2.urlopen('http://example.com/api/?foo=bad-query-string')
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
  ...
urllib2.HTTPError: HTTP Error 400: Bad Request

德拉特,回复的正文说了什么?它可能包含有价值的错误信息......

我意识到重新运行包含在 try/except 中的代码通常很容易,但这并不理想。我也意识到,在这种特定情况下,如果我使用requests库(不会引发 HTTP 错误),我不会遇到这个问题......但我真的想知道是否有更通用的方法来获取在这些情况下,Python 提示符处的最后一个异常对象。

4

2 回答 2

78

sys模块提供了一些用于事后检查异常的功能:sys.last_typesys.last_valuesys.last_traceback

sys.last_value是你要找的那个。

于 2013-03-25T01:06:42.373 回答
30

正如@Cairnarvon 提到的,我没有发现任何last_value成员是 sys 模块。

sys.exc_info()为我做了伎俩。sys.exc_info()返回具有三个值的元组(type, value, traceback)

所以sys.exc_info()[1]会给出可读的错误。这是示例,

import sys
list = [1,2,3,4]
try:
    del list[8]
except Exception:
    print(sys.exc_info()[1])

将输出list assignment index out of range

此外,traceback.format_exc()fromtraceback模块可用于打印出类似的信息。

以下是format_exec()使用时的输出,

Traceback (most recent call last):
  File "python", line 6, in <module>
IndexError: list assignment index out of range
于 2017-01-16T05:50:24.253 回答