Python中编码问题:u'\xe6\x97\xa0\xe5\x90\x8d' 类型的转为utf-8的解决办法
相信小伙伴们遇到过类似这样的问题,python2中各种头疼的转码,类似u'\xe6\x97\xa0\xe5\x90\x8d' 的编码,直接s.decode()是无法解决编码问题。尝试了无数办法,都无法解决。
最终得到完美的解决办法:
s = u'\xe6\x97\xa0\xe5\x90\x8d' s2 = s.encode('raw_unicode_escape')
print s2 ---->无名
python十六进制字符码转中文很简单,只需decode,再encode即可。
例:现在有一串utf-8的十六进制字符码串, ‘i am request,\xE6\x88\x91\xE6\x98\xAF\xE8\xAF\xB7\xE6\xB1\x82'
a = 'i am request,\xE6\x88\x91\xE6\x98\xAF\xE8\xAF\xB7\xE6\xB1\x82'.decode('utf-8').encode('utf-8') print a
输出:i am request,我是请求
假设s='中国'
那么print repr(s)得到的就是16进制字符串
而print s得到的是汉字
> s='中国' > s '\xe4\xb8\xad\xe5\x9b\xbd' > print s 中国 > print repr(s) '\xe4\xb8\xad\xe5\x9b\xbd' >
以上这篇Python 16进制与中文相互转换的实现方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。