像Python一样格式化异常

时间:2016-02-19 06:18:05

标签: python exception string-formatting

如果我在Python中引发异常,这就是我得到的:

raise Exception("Hello world")
Traceback (most recent call last):

  File "<ipython-input-24-dd3f3f45afbe>", line 1, in <module>
    raise Exception("Hello world")

Exception: Hello world

请注意Exception: Hello world的最后一行。给定异常(foo = Exception("Hello world")),我该如何生成这样的文本?以下工作均不起作用:

str(foo)
Out[27]: 'Hello world'

repr(foo)
Out[28]: "Exception('Hello world',)"

"{}".format(foo)
Out[29]: 'Hello world'

"{}: {}".format(type(foo), foo)
Out[30]: "<type 'exceptions.Exception'>: Hello world"

2 个答案:

答案 0 :(得分:9)

如果您的例外对象是exc,那么:

  • 冒号前的部分为type(exc).__name__
  • 冒号后的部分为str(exc)

所以你可以这样做:

print('{}: {}'.format(type(exc).__name__, exc))

答案 1 :(得分:2)

使tdelaney的回答正式并证明其中的不同...

字符串

#test.py
import traceback

try :
    raise TypeError("Wrong Type baby!")

except Exception, e:
    print( "EXCEPTION FORMAT PRINT:\n{}".format( e ) )
    print( "EXCEPTION TRACE  PRINT:\n{}".format( traceback.format_exc(e) ) )

结果控制台输出

EXCEPTION FORMAT PRINT:
Wrong Type baby!
EXCEPTION TRACE  PRINT:
Traceback (most recent call last):
  File "/Users/me/test.py", line 4, in <module>
    raise TypeError("Wrong Type baby!")
TypeError: Wrong Type baby!

记录

如果您处于记录环境中,那么还有一种exception方法将为您进行格式化。

# logTest.py
import logging

try :
    raise ValueError("my bad value")
except Exception , e :
    logging.exception( e )

与最终的控制台输出...

ERROR:root:my bad value
Traceback (most recent call last):
  File "/Users/me/logTest.py", line 4, in <module>
    raise ValueError("my bad value")
ValueError: my bad value