如何引发包含Unicode字符串的Exception?

时间:2015-03-17 10:26:52

标签: python python-2.7 unicode pyqt

我正在使用Unicode字符串编写Python 2代码,导入unicode_literals并且我遇到了引发异常的问题。

# -*- coding: utf-8 -*-

from __future__ import unicode_literals

raise Exception('Tést')

执行此操作时,“Tést”字符串将从终端上删除。

我可以用

解决这个问题
raise Exception('Tést'.encode('utf-8'))

我宁愿找到一个全局解决方案而不是必须在所有raise Exception语句中执行此操作。

(因为我在Exception消息中使用PyQt的tr()函数,必须处理特殊字符,我在编码时无法知道是否需要encode('utf-8')。)

更糟。有时候,我想捕获一个Exception,获取它的消息,然后引发一个新的Exception,将一个基本字符串与第一个Exception字符串连接起来。

我必须这样做:

try:
    raise TypeError('Tést'.encode('utf-8'))
except Exception as e:
    raise Exception('Exception: {}'.format(str(e).decode('utf-8')).encode('utf-8'))

但我真的希望它可以不那么麻烦(这个例子甚至不包括self.tr()次调用)。

有没有更简单的方法?

(作为一个附带问题,使用Python3更简单吗?Exception可以使用unicode字符串吗?)

1 个答案:

答案 0 :(得分:12)

感谢问题下面的评论,我想出了这个。

我们的想法是使用自定义的Exception子类。

# -*- coding: utf-8 -*-

from __future__ import unicode_literals

class MyException(Exception):

    def __init__(self, message):

        if isinstance(message, unicode):
            super(MyException, self).__init__(message.encode('utf-8'))
            self.message = message

        elif isinstance(message, str):
            super(MyException, self).__init__(message)
            self.message = message.decode('utf-8')

        # This shouldn't happen...
        else:
            raise TypeError

    def __unicode__(self):

        return self.message

class MySubException(MyException):
    pass

try:
    raise MyException('Tést')
except MyException as e:
    print(e.message)
    raise MySubException('SubException: {}'.format(e))