- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我已阅读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/
我使用术语“词法编码”是因为我没有更好的编码。 与字母相反,单词可以说是交流的基本单位。 Unicode 尝试为所有已知字母表的每个字母分配一个数值。对一种语言来说是字母,对另一种语言来说是字形。 U
我在UTF-8中有csv文件,我想将其保存在西里尔字母(Windows 1251)中...在中,我仅找到Atom -重新打开,并使用ctrl+shift+u编码 在 Sublime Text 3 中,
在lua 5.3引用手册中,我们可以看到: Lua is also encoding-agnostic; it makes no assumptions about the contents of a
看完后how gzip compression works它让我思考。如果源和代理服务器 (CDN) 都支持 gzip,则添加 Vary: Accept-Encoding头需要吗? 最佳答案 Vary
我正在向我的项目添加一项功能,我们将生成指向我们网站内部内容的链接,并且我们希望这些链接尽可能短,因此我们将制作自己的“URL 缩短器”。 我想知道生成的短网址的最佳编码/字母表是什么。这很大程度上是
我构建了一个用于压缩 HTTP 输出的模块。阅读spec ,我在以下几件事上没有发现明显的区别: 接受编码: 是否应将其视为与 Accept-Encoding: * 相同,还是视为不存在 header
在下面的代码中: package main import ( "bytes" "encoding/json" "fmt" ) type Student struct {
这个问题在这里已经有了答案: Why does encode delete the argument? (1 个回答) 6年前关闭。 Encode::encode 的文档说: encode $octe
在Android4.1中,实时编码应用中经常会请求关键帧。但是如何使用 MediaCodec 对象呢?当前的 Android4.2 SDK 似乎不支持它。 最佳答案 您可以 通过在排队输入缓冲区时指定
我有 CSV 格式的数据,这些数据在字符编码方面被严重打乱,可能在不同的软件应用程序(LibreOffice Calc、Microsoft、Excel、Google Refine、自定义 PHP/My
您可能知道,在 Perl 中,“utf8”意味着 Perl 对 UTF-8 的宽松理解,它允许使用技术上不是 UTF-8 中有效代码点的字符。相比之下,“UTF-8”(或“utf-8”)是 Perl
本文整理了Java中org.geotools.ysld.encode.YsldEncoder.encode()方法的一些代码示例,展示了YsldEncoder.encode()的具体用法。这些代码示例
现在还没有任何关于红色的书,因为它太新了。因此,我正在尝试遵循一本旧的 Rebol 书,并从中挽救我能得到的东西。 我发现一些命令,例如 read,由于文件编码的原因,我无法执行代码。 save %
错误:无法映射用于编码 UTF-8 的字符。由于版权特征,我收到此错误。我使用的是 Netbeans 7.2。 /** * � 2006 * * This class was generate
现在还没有任何关于红色的书,因为它太新了。因此,我正在尝试遵循一本旧的 Rebol 书,并从中挽救我能得到的东西。 我发现一些命令,例如 read,由于文件编码的原因,我无法执行代码。 save %
错误:无法映射用于编码 UTF-8 的字符。由于版权特征,我收到此错误。我使用的是 Netbeans 7.2。 /** * � 2006 * * This class was generate
我正在尝试使用客户端提供的值在 PHP 中测试 Soap Security header 。 他们提供的值(value)如... wTAmCL9tmg6KNpeAQOYubw== ...并说这是一个
这个问题已经有答案了: ClassNotFoundException/NoClassDefFoundError in my Java web application (3 个回答) 已关闭 8 年前。
世界!我正在使用 .Net Framework 4 System.Net.Sockets.TcpClient 编写简单的 HTML 服务器。 我在 StringBuilder html 中有 HTML
我正在尝试使用 Yii 来提供网络服务。自动生成的 wsdl 如下。我可以从命令行成功使用 Web 服务,但是通过 Web 浏览器,我得到了 SOAP-ERROR: Encoding: Violati
我是一名优秀的程序员,十分优秀!