python unicode转中文及转换默认编码

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了python unicode转中文及转换默认编码相关的知识,希望对你有一定的参考价值。

一、 

 在爬虫抓取网页信息时常需要将类似"\u4eba\u751f\u82e6\u77ed\uff0cpy\u662f\u5cb8"转换为中文,实际上这是unicode的中文编码。可用以下方法转换:

1、

1 >>> s = u\u4eba\u751f\u82e6\u77ed\uff0cpy\u662f\u5cb8
2 >>> print s
3 人生苦短,py是岸

2、

1 >>> s = r\u4eba\u751f\u82e6\u77ed\uff0cpy\u662f\u5cb8
2 >>> s = s.decode(unicode_escape)
3 >>> print s
4 人生苦短,py是岸

 

二、

  另外,在python2的字符编码问题时常会遇到“UnicodeEncodeError: ‘ascii‘ codec can‘t encode characters in position 0-5: ordinal not in range(128)”的编码错误。

而用以下方法通常可以解决:

1 import sys
2 reload(sys)
3 sys.setdefaultencoding(utf-8)

  此方法是将Python2的默认编码ASCII改为 utf-8。但此方法不是一劳永逸的,可能会使一些代码的行为变得怪异。

  可以参考该连接:http://blog.ernest.me/post/python-setdefaultencoding-unicode-bytes

以上是关于python unicode转中文及转换默认编码的主要内容,如果未能解决你的问题,请参考以下文章

python 2 与 python 3 —— 转义及编码(u x)

怎样将unicode转化成中文

编码转换

编码转换

Python json unicode转中文

python 字符串格式的unicode编码转中文