python 文件里的中文在 windows 下运行乱码

在 py 文件的头部加了

#!/usr/bin/env python
# -*- coding: utf-8 -*-

而且有中文字符串的地方都用了u'中文字符串',但是在 windows 下还是乱码,linux 下不会,如何解决?

补充

raw_input('中文字符串') 这个容易乱码,可以用这个来测试

阅读 31.2k
4 个回答

我认为楼上的回答是不准确的.
以下是我在一个干净的XP(虚拟机)里用cmd跑python 2.7.3测试的结果:

交互式

文件执行
(文件另存为选择了UTF-8编码)

建议楼主在文件头加上

from __future__ import unicode_literals

然后去掉所有字符串前的 u, 这样所有字符串均默认为unicode串 :)

关于中文编码相关问题, 还可以参考 http://segmentfault.com/q/10100000000...

华丽的分割线

raw_input 的地方我测试了, 确实得encode. 建议用mbcs(其实用sys的那几个get方法拿到的也是这个), 表示微软的格式.

raw_input

新手上路,请多包涵

其实你用IDLE,不用微软的垃圾CMD就行了

新手上路,请多包涵

修改成GBK即可

例如:

图片描述

新手上路,请多包涵

下面这个方法可以彻底解决!
1、确保py文件是UTF-8编码存档的。
2、在CMD窗口输入CHCP 65001 回车。(65001是win系统UTF-8的代码)
3、选择字体Lucida Console。说明:如果想在CMD显示更多的字体,在注册表(路径:HKEY_LOCAL_MACHINESOFTWAREMicrosoftWindows NTCurrentVersionConsoleTrueTypeFont)中添加就好了。添加的字体需要是定宽的(fixed-width)。问题彻底解决。

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题
logo
Microsoft
子站问答
访问
宣传栏