【问题标题】:UnicodeEncodeError: 'ascii' codec can't encode character [...]UnicodeEncodeError:“ascii”编解码器无法编码字符 [...]
【发布时间】:2012-07-02 09:45:24
【问题描述】:

我已经阅读了官方文档中的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 也位于开头。

接下来我将生成的 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__()

从文档中我得到了这个

【问题讨论】:

  • print obj 将使用对象的__str__,而不是__repr__
  • 您的默认编码是什么?我的意思是 sys.getdefaultencoding()
  • @BrenBarn : str 实现为 return __repr__()
  • @MaksymPolshcha:按功能是ascii
  • 我真的建议您看看 Pycon 2012 Pragmatic Unicode 上的这个演讲,或者,我该如何停止痛苦? youtube.com/watch?v=sgHbC6udIqc

标签: python unicode


【解决方案1】:

我终于解决了。问题是(我不知道为什么)如果你直接调用__str__()__repr__() 处理它会很高兴,但是直接打印它(如:print obj)不起作用(尽管它应该只调用 __str__() 本身)。

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

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

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

【讨论】:

  • 帮助文章不再可用
猜你喜欢
  • 2015-10-21
  • 2010-12-11
  • 2010-12-11
  • 2021-09-28
  • 2017-02-01
  • 2016-12-17
  • 2013-04-21
相关资源
最近更新 更多