python - UnicodeEncodeError : 'ascii' codec can't encode character [. ..]

标签 python unicode

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

这是我的尝试:我打开一个 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并将其分配给我类(class)中的一个变量。

现在最完美的是这些命令(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__()

从文档中我得到了这个

最佳答案

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

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

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

现在剩下的唯一悬而未决的问题是:为什么 print obj.__str__()print obj 与此不同?这对我来说毫无意义。是的,再次强调:调用前者或 __repr__() 确实有效。并且仍然使用显式编码。

关于python - UnicodeEncodeError : 'ascii' codec can't encode character [. ..],我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11285866/

相关文章:

java - 是否可以仅将特殊字符转换为 unicode?

c# - 如何在 .NET 中显示古埃及象形文字?

unicode - 清理 Unicode 输入的最佳实践

python - 通过采样其他列的位来创建新列

c - 如何使用 C 从字符串中获取 UTF-8 字符?

python - django 在保留数据的同时将 OneToOneField 移动到外键

python - 文件扩展名 Python

c# - 为什么在使用 IndexOf(string) 和 IndexOf(char) 时,非组合变音符号前面的空格会产生不同的作用?

python - mingw + python 热切翻译路径

python - POST 数据对 Django 模板变量有错误的值?