扫码关注官方订阅号
在 py 文件的头部加了
#!/usr/bin/env python # -*- coding: utf-8 -*-
而且有中文字符串的地方都用了u'中文字符串',但是在 windows 下还是乱码,linux 下不会,如何解决?
u'中文字符串'
raw_input('中文字符串') 这个容易乱码,可以用这个来测试
raw_input('中文字符串')
认证0级讲师
我认为楼上的回答是不准确的. 以下是我在一个干净的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方法拿到的也是这个), 表示微软的格式.
其实你用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)。问题彻底解决。
微信扫码关注PHP中文网服务号
QQ扫码加入技术交流群
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号
PHP学习
技术支持
返回顶部
我认为楼上的回答是不准确的.
以下是我在一个干净的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方法拿到的也是这个), 表示微软的格式.
其实你用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)。问题彻底解决。