如何自定义异常消息

时间:2016-11-17 06:50:26

标签: python python-3.x

# python 3.5
>>> class MyError(Exception):
...   pass
...
>>> raise MyError('message')
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
__main__.MyError: message

我希望异常仅打印message而不是__main__.MyError: message。我在__str__本身及其元类中尝试了定义__repr__MyError,但这些都没有效果。 python解释器从哪里获得__main__.MyError

请注意,我可以轻松更改MyError的实例的打印方式,以及MyError本身的打印方式,但不会对异常消息产生任何影响:

class MyType(type):
  def __str__(self):
    return '***'

class MyError(Exception, metaclass=MyType):
  def __str__(self):
    return 'xxx'

print(MyError) # ***
print(MyError()) # xxx
raise MyError() # still the same

2 个答案:

答案 0 :(得分:2)

我能得到的最接近的是:

In [6]: raise MyError("some message")
---------------------------------------------------------------------------
MyError                                   Traceback (most recent call last)
<ipython-input-2-4bd48c5b1ce0> in <module>()
----> 1 raise MyError("some error message")

MyError: some error message

有一种方法可以删除类名前面的前导__main__.文本。甚至有一种方法可以删除类名,因此输出如下所示:

In [6]: raise MyError("some error message")
---------------------------------------------------------------------------
                                          Traceback (most recent call last)
<ipython-input-6-4bd48c5b1ce0> in <module>()
----> 1 raise MyError("some error message")

: some error message

但是,我无法找到删除:符号的方法。我的猜测是这个符号是由解释器生成的,以便将异常输出与其他输出类型清楚地分开。

这是我使用的解决方案:

class MyError(Exception):
    __module__ = None
    def __init__(self, *args, **kwargs):
        Exception.__init__(self, *args, **kwargs)
        self.__class__.__name__ = "CustomTextHere"

还有一些产出:

In [8]: MyError
Out[8]: MyError

In [9]: MyError()
Out[9]: None.CustomTextHere()

In [11]: raise MyError()
---------------------------------------------------------------------------
CustomTextHere                            Traceback (most recent call last)
<ipython-input-11-f389ee70e588> in <module>()
----> 1 raise MyError()

CustomTextHere: 

In [12]: raise MyError("some error message")
---------------------------------------------------------------------------
CustomTextHere                            Traceback (most recent call last)
<ipython-input-12-4bd48c5b1ce0> in <module>()
----> 1 raise MyError("some error message")

CustomTextHere: some error message

如果您只想获得:符号,请使用:

self.__class__.__name__ = ""

答案 1 :(得分:1)

该行的第一部分,在冒号之前,是异常引发的类型。它的格式与返回的格式相同:

>>> class MyError(Exception):
...     pass
...
>>> print(type(MyError("message")))
<class '__main__.MyError'>

通常,您的自定义异常类将放在某个文件(例如,file.py)中并导入,因此在这种情况下,它将file.MyError而不是__main__.MyError。但是,由于您当前正在使用主python文件中定义的Exception,因此它必须使用的唯一命名空间是__main__

长话短说,如果你想让它更漂亮,可以把它放在另一个你喜欢这个名字的文件中。