python 中文编码类型 gb2312 gb180_关于Python中的中文编码问题

这篇文章介绍的内容是关于Python中的中文编码问题,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下

1.python中的中文编码问题

1.1 .py文件中的编码

Python 默认脚本文件都是 ANSCII 编码的,当文件 中有非 ANSCII 编码范围内的字符的时候就要使用"编码指示"来修正。 一个module的定义中,如果.py文件中包含中文字符(严格的说是含有非anscii字符),则需要在第一行或第二行指定编码声明:

# -*- coding=utf-8 -*-或者 #coding=utf-8 其他的编码如:gbk、gb2312也可以; 否则会出现类似:SyntaxError: Non-ASCII character '/xe4' in file ChineseTest.py on line 1, but no encoding declared; see http://www.pytho for details这样的异常信息;n.org/peps/pep-0263.html

1.2 python中的编码与解码

先说一下python中的字符串类型,在python中有两种字符串类型,分别是str和unicode,他们都是basestring的派生类;str类型是一个包含Characters represent (at least) 8-bit bytes的序列;unicode的每个unit是一个unicode obj;所以:

len(u'中国')的值是2;len('ab')的值也是2;

在str的文档中有这样的一句话:The string data type is also used to represent arrays of bytes, e.g., to hold data read from a file. 也就是说在读取一个文件的内容,或者从网络上读取到内容时,保持的对象为str类型;如果想把一个str转换成特定编码类型,需要把str转为Unicode,然后从unicode转为特定的编码类型如:utf-8、gb2312等;

python中提供的转换函数:

unicode转为 gb2312,utf-8等# -*- coding=UTF-8 -*-

if __name__ == '__main__':

s = u'中国'

s_gb = s.encode('gb2312')

utf-8,GBK转换为unicode 使用函数unicode(s,encoding) 或者s.decode(encoding)# -*- coding=UTF-8 -*-

if __name__ == '__main__': s = u'中国'

#s为unicode先转为utf-8

s_utf8 = s.encode('UTF-8')

assert(s_utf8.decode('utf-8') == s)

普通的str转为unicode# -*- coding=UTF-8 -*-

if __name__ == '__main__': s = '中国'

su = u'中国

你可能感兴趣的:(python,中文编码类型,gb2312,gb180)