问题:使用notepad++或sublime text3编辑的python文件若是含有中文,使用python2.7运行会出现乱码。python
缘由:windows
windows的本地默认编码是gbk编码。python2.7
notepad++、windows自己的写字板以及sublime text3的默认编码都是utf-8。编辑器
windows记事本的默认编码是ANSI。ANSI并非某一种特定的字符编码,而是在不一样的系统中,ANSI表示不一样的编码。在中文系统中就是gbk编码。编码
这就是为何用记事本编辑的python文件,用python2.7运行中文不会出现乱码。而用notepad++、windows自己的写字板以及sublime text3编辑的python文件,用python2.7运行中文会出现乱码的缘由。命令行
解决方法:code
1、经过将中文先解码(解码成unicode码)再编码(编码成gbk)的方式解决,以下: blog
# coding=utf-8 # 等待用户输入 inp=raw_input("请输入用户名:".decode("utf-8").encode("gbk")) print inp
2、在编辑器中设置编码格式ip
备注:utf-8
那么Windows系统是如何区分ANSI背后的真实编码的呢?
微软用一个叫“Windows code pages”(在命令行下执行chcp命令能够查看当前code page的值)的值来判断系统默认编码,好比:简体中文的code page值为936(它表示GBK编码,win95以前表示GB2312,详见:Microsoft Windows' Code Page 936),繁体中文的code page值为950(表示Big-5编码)。