- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我有一些代表外国名字的 python 字符串形式的文本:
Graziano Pellè
Sergio Agüero
Cesc Fàbregas
我正在使用以下语法对字符串进行编码:
(string).encode('utf-8')
然而这打印:
Graziano Pellè
Sergio Agüero
Cesc FÃ bregas
当字符串同时打印到 Command Shell 和 Python Shell 时会发生这种情况,但我不明白为什么。我的印象是通用字符集支持大多数主要语言的字母表。如果这不是要使用的正确编码,我应该改用什么?
谢谢
最佳答案
问题是您的终端窗口(我假设为 cmd.exe
,因为这听起来像 Windows)不是 UTF-8,而是一些类似 Latin-1 的字符集,例如 Windows-1252。
因此,您将这些 Unicode 字符串编码为 UTF-8 字节序列,然后将它们发送到终端,终端将这些 UTF-8 字节序列解释为 Windows-1252 字节序列,并将它们显示为垃圾。
例如,u"Graziano Pellè"
,当编码为 UTF-8 时,是:
'Graziano Pell\xc3\xa8'
为什么?那么,在 UTF-8 中,ASCII 字符编码为一个字节,所以 G
,又名 U+0047,变成单字节 0x47
,看起来像 G
在几乎任何字符集中,但非 ASCII 字符编码为两个或更多字节,所以 è
,又名 U+00E8,变为 0xc3
和 0xa8
.在 Windows-1252 中,0xc3
是字符 Ã
, 和 0xa8
是字符 ¨
.
此处的简单解决方案(如果您的 Python 能够正确检测终端的字符集)是直接打印 Unicode 字符串。
如果不是,您必须以某种方式查找字符集(或者只是硬编码它,如果这仅供本地使用;它可能是 cp1252
,但您可以在系统偏好设置中找到它作为“OEM 代码页”) 并编码为那个,而不是 UTF-8。
最后一件事:
I was of the impression that the universal character set supports alphabets from most major languages.
确实如此。* 但问题是您不能只将 Unicode 写入控制台;你必须写字节。** 问题就变成了,哪些字节?如果您写入 UTF-8 字节,而终端期望 cp1252 字节,您会得到 mojibake。
* 实际上,“通用字符集”通常是指 ISO-60464 或 UCS 2,而不是现代 Unicode……但它们对于前 61K 左右的字符是相同的,所以让我们假设它们足够接近……
** 在 Windows 上实际上不是这样;您可以改写 16 位字,并且保证将它们解释为 UTF-16。但是 Python 2.x 不知道如何以这种方式使用 Windows 控制台,所以除非您想直接开始进行 Win32 API 调用而不是使用像 print
这样友好的东西,否则这对您没有帮助。 .
关于python - .encode ('utf-8' ) 打印奇怪的字符,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26027406/
我使用术语“词法编码”是因为我没有更好的编码。 与字母相反,单词可以说是交流的基本单位。 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
我是一名优秀的程序员,十分优秀!