Python 16进制与中文相互转换
相信小伙伴们遇到过类似这样的问题,python2中各种头疼的转码,类似u"xe6x97xa0xe5x90x8d" 的编码,直接s.decode()是无法解决编码问题。尝试了无数办法,都无法解决。
最终得到完美的解决办法:
s = u"xe6x97xa0xe5x90x8d"
s2 = s.encode("raw_unicode_escape")
print s2 ---->无名
python十六进制字符码转中文很简单,只需decode,再encode即可。
例:现在有一串utf-8的十六进制字符码串, ‘i am request,xE6x88x91xE6x98xAFxE8xAFxB7xE6xB1x82’
a = "i am request,xE6x88x91xE6x98xAFxE8xAFxB7xE6xB1x82".decode("utf-8").encode("utf-8")
print a
输出:i am request,我是请求
假设s="中国"
那么print repr(s)得到的就是16进制字符串
而print s得到的是汉字
>>> s="中国"
>>> s
"xe4xb8xadxe5x9bxbd"
>>> print s
中国
>>> print repr(s)
"xe4xb8xadxe5x9bxbd"
>>>
声明:该文观点仅代表作者本人,牛骨文系教育信息发布平台,牛骨文仅提供信息存储空间服务。
- 上一篇: JS中attr和prop属性的区别,以及优先选择
- 下一篇: Nginx配置文件详细说明