我已阅读如何非 Unicode http://docs.python.org/howto/unicode.html来自官方文档和完整、非常详细的article http://boodebr.org/main/python/all-about-python-and-unicode以及。我仍然不明白为什么它会抛出这个错误。
以下是我尝试的操作:我打开一个 XML 文件,其中包含超出 ASCII 范围的字符(但在允许的 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
这也是一开始的事。
接下来,我将生成的对象传递给我自己的类,在其中将标签读入变量中,如下所示: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__()
从文档中我得知这个