UnicodeEncodeError:'ascii'编解码器不能编码字符[...]

时间:2012-07-01 21:45:32

标签: python unicode

我已阅读官方文档中的HOWTO on Unicode以及完整,非常详细的article。我仍然不明白为什么它会把这个错误抛给我。

这是我尝试的内容:我打开一个包含ASCII范围内的字符的XML文件(但在允许的XML范围内)。我这样做cfg = codecs.open(filename, encoding='utf-8, mode='r')运行正常。查看带有repr()的字符串也会显示一个unicode字符串。

现在我继续阅读parseString(cfg.read().encode('utf-8')。当然,我的XML文件以此开头:<?xml version="1.0" encoding="utf-8"?>。虽然我认为它不相关,但我也为我的python脚本定义了utf-8,但由于我不直接在其中编写unicode字符,所以这不应该适用于此。对于以下行也是如此:from __future__ import unicode_literals在开头也是正确的。

接下来我将生成的Object传递给我自己的类,在那里我将标签读入这样的变量:xmldata.getElementsByTagName(tagName)[0].firstChild.data并将其分配给我班级中的变量。

现在完全有效的是那些命令(obj是类的一个实例):

for element in obj:
    print element

此命令也可以正常工作:

print obj.__repr__()

我定义__iter__()只生成每个变量,而__repr__()使用典型的printf内容:"%s" % self.varname

两个命令都可以完美打印并输出unicode字符。 什么不起作用是这样的:

print obj

现在我被卡住了,因为这会引发可怕的

UnicodeEncodeError: 'ascii' codec can't encode character u'\xfc' in position 47:

那我错过了什么?我究竟做错了什么?我正在寻找一个通用的解决方案,我总是希望将字符串作为unicode处理,只是为了避免任何可能的错误并编写兼容的程序。

编辑:我也定义了这个:

def __str__(self):
    return self.__repr__()
def __unicode__(self):
    return self.__repr__()

从文档中我得到了这个

1 个答案:

答案 0 :(得分:4)

我终于解决了它。问题是(我不知道为什么),如果你直接调用__str__()__repr__(),那么就可以很好地处理它,但是直接打印它(如:print obj)不起作用(虽然它应该只调用__str__()本身)。

最后的帮助来自article。当我使用utf-8编码时,我已经到了打印到控制台(但是错误的字母)的步骤。最后通过定义它来解决它是完全正确的:

def __str__(self):
    return self.__repr__().encode(stdout.encoding)

现在唯一尚未解决的问题是:为什么print obj.__str__()print obj与此不同?这对我来说毫无意义。是的,再次强调:呼叫前者或__repr__() DID工作。并且仍然使用显式编码。