unicode编码转换中文_python

1.python3 解决方案
python3似乎对一切的unicode都那么的友好,当一个字符串里存在unicode的时候,只要字符串是硬编码的,就可以转换成中文打印在控制台上,如:

s = ‘\u7b14\u8bb0’
print(s)

你得到的就是中文汉字。
但是,假如你。。的这段含有‘\u’的unicode编码不是硬编码进脚本的,而是通过requests在网上爬的。。。那么你会发现,你打印出来的,还是长这样的unicode编码,换句话说,解释器这个时候根本就没认出这东西原来是unicode编码,当成普通的字符序列了。
百度找到了最好的解决方法:在这个unicode串后面加上:

description = b"\u662f\u5bf9\u624b\u4e5f\u662f\u670b\u53cb\uff01\u5965\u8fd0\u8d5b\u573a\u4e0a\u7ade\u4e89\u4e4b\u5916\u7684\u6e29\u67d4\u65f6\u523b\u8ba9\u4eba\u6cea\u76ee,\u672c\u89c6\u9891\u7531\u62bd\u5c49\u89c6\u9891\u539f\u521b\u63d0\u4f9b,358\u6b21\u64ad\u653e,\u597d\u770b\u89c6\u9891\u662f\u7531\u767e\u5ea6\u56e2\u961f\u6253\u9020\u7684\u96c6\u5185\u6db5\u548c\u989c\u503c\u4e8e\u4e00\u8eab\u7684\u4e13\u4e1a\u77ed\u89c6\u9891\u805a\u5408\u5e73\u53f0"

s = description.decode('unicode_escape')
print(s)

s --->>>是对手也是朋友!奥运赛场上竞争之外的温柔时刻让人泪目,本视频由抽屉视频原创提供,358次播放,好看视频是由百度团队打造的集内涵和颜值于一身的专业短视频聚合平台

它就打印出汉字了

2.python2 解决方案

1 import sys
2 reload(sys)
3 sys.setdefaultencoding('utf-8')
  此方法是将Python2的默认编码ASCII改为 utf-8。但此方法不是一劳永逸的,可能会使一些代码的行为变得怪异。

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

posted @ 2020-12-06 22:39  三省吾身~  阅读(2119)  评论(0编辑  收藏  举报