python2.七、notepad++及sublime text3中文乱码

问题:使用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编码)。

相关文章
相关标签/搜索