![](/img/trans.png)
[英]Why did I get UnicodeDecodeError when I read a file which contains Chinese characters?
[英]Why I cannot save file with Chinese characters when using Python 2.7.11 IDLE?
我刚刚从它的官方网站下载了最新的Python 2.7.11 64bit,并将其安装到我的Windows 10。我发现如果新的IDLE文件包含汉字,比如你好,那么我无法保存文件。 如果我多次尝试保存它,那么新文件就会崩溃并消失。
我也安装了最新的python-3.5.1-amd64.exe,也没有这个问题。
如何解决?
更多:来自wiki页面的示例代码, https://zh.wikipedia.org/wiki/%E9%B8%AD%E5%AD%90%E7%B1%BB%E5%9E%8B
如果我通过此处的代码,StackOverflow 会警告我:Body cannot contain "I just dow"。 为什么?
谢谢!
更多:我找到了这个配置选项,但它根本没有帮助。 IDLE -> 选项 -> 配置 IDLE -> 常规 -> 默认源编码:UTF-8
Python 2.x 使用 ASCII 作为默认编码,而 Python 3.x 使用 UTF-8。 只需使用:
my_string.encode("utf-8")
将 ascii 转换为 utf-8(或将其更改为您需要的任何其他编码)
您也可以尝试将此行放在代码的第一行:
# -*- coding: utf-8 -*-
Python 2 使用 ASCII 作为其不能存储中文字符的字符串的默认编码。 另一方面,Python 3 的字符串默认使用 Unicode 编码,可以存储汉字。
但这并不意味着 Python 2 不能使用 Unicode 字符串。 您只需将字符串编码为 Unicode。 下面是将字符串转换为 Unicode 字符串的示例。
>>> plain_text = "Plain text"
>>> plain_text
'Plain text'
>>> utf8_text = unicode(plain_text, "utf-8")
>>> utf8_txt
u'Plain_text'
字符串utf8_txt
中的前缀u
表示它是一个 Unicode 字符串。
你也可以这样做。
>>> print u"你好"
>>> 你好
您只需要在您的字符串前加上u
来表示它是一个 Unicode 字符串。
在 Windows 上使用 Python 2 时:
对于要保存在 IDLE 中的具有 Unicode 字符的文件,一行
# -*- coding: utf-8 -*-
必须在其开头添加。
为了使 Unicode 字符在 Windows 的控制台输出中正确显示,如果运行脚本,保存在文件中,在 IDLE 控制台或 Windows shell 中,字符串必须以u
开头:
print u"你好" print u"Привет"
但是在交互模式下,我发现西里尔字母不需要这个。
即使在 python 3.7 中我仍然遇到同样的问题,UTF-8 仍然可以解决问题
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.