强大的unicode转换,允许打印[重复]

问题描述 投票:0回答:1

这个问题在这里已有答案:

我正在比较两个字典列表的等价性。数据来自我无法控制的两个来源。如果任何字段不同,我打印出两个值:

        if event[field_name] == other_event[field_name]:
            print field_name, u'OK,'
        else:
            print field_name, u':', event[field_name], other_event[field_name]

但是,这些数据本质上是国际性的,它似乎沿着该行的某个地方变成了ascii编码,因此有时我会收到以下错误:

UnicodeEncodeError: 'ascii' codec can't encode character u'\xfc' in position 11: ordinal not in range(128)

转换数据的最佳方法是什么,以便可以在没有错误的情况下打印数据?请注意,数据不是所有文本,例如它可能是布尔值或整数甚至是无,因此需要一种能够以类似的方式处理非字符串的解决方案。

这个代码运行的平台有Python 2(准确地说是Python 2.7.10),但如果解决方案也兼容Python 3将是有利的,因为它可能需要在未来的Python 3环境中运行。

我检查了Handle wrongly encoded character in Python unicode string,但我的问题似乎有所不同,因为我可以在交互式提示符下输出u'\ xfc':

>>> print u'Gl\xfcck'
Glück

谢谢

python python-2.7 unicode output python-unicode
1个回答
0
投票

这有效:

import sys  # import sys package, if not already imported
reload(sys)
sys.setdefaultencoding('utf-8')

这是来自Handle wrongly encoded character in Python unicode string,但是从接受的答案中得到了几个答案。

© www.soinside.com 2019 - 2024. All rights reserved.