【Python】汉字十六进制乱码问题的解决(Python2.7、3.7)

  • A+
所属分类:未分类

【py2.7】
问题:出现类似于这样的乱码

s='\xe4\xb8\xad\xe5\x9b\xbd\xe5\xa4\x96\xe6\xb1\x87\xe4\xba\xa4\xe6\x98\x93\xe4\xb8\xad\xe5\xbf\x83\xe5\x85\xb3\xe4\xba\x8e\xe5\xbc\x80\xe5\xb1\x952020\xe5\xb9\xb4\xe5\xba\xa6\xe9\x93\xb6\xe8\xa1\x8c\xe9\x97\xb4\xe5\xa4\x96\xe6\xb1\x87\xe5\xb8\x82\xe5\x9c\xba\xe4\xbc\x98\xe7\xa7\x80\xe4\xba\xa4\xe6\x98\x93\xe4\xb8\xbb\xe7\xae\xa1\xe5\x92\x8c\xe4\xbc\x98\xe7\xa7\x80\xe4\xba\xa4\xe6\x98\x93\xe5\x91\x98\xe6\x8f\x90\xe5\x90\x8d\xe5\xb7\xa5\xe4\xbd\x9c\xe7\x9a\x84\xe9\x80\x9a\xe7\x9f\xa5(FBM-CLI-4-350095).doc'
  • 1
  • 首先,通过type函数确定s的类型,虽然s的内容是unicode编码格式,但是s的类型可能是str、bytes、unicode三种情况,s是str类型的在python2.7中常见,bytes类型在python3.7中常见。
  • 当type(s)是str类型的内容为unicode的字符串,此时只需要使用一个函数即可将s变成汉字表示的字符串:
    有两种方法:
    方法1:(推荐)
s=bytes(s)
print(s,type(s))
  • 1
  • 2

此时s的类型变成str,s的内容也是汉字形式的字符串
方法2:

s.encode('utf-8')
  • 1

此时s的类型是unicode,但是s输出的内容是汉字的形式
【py3.7】
s类型是str类型的时候就不能像py2.7那样处理了

s = u'\xe4\xb8\xad\xe5\x9b\xbd\xe5\xa4\x96\xe6\xb1\x87\xe4\xba\xa4\xe6\x98\x93\xe4\xb8\xad\xe5\xbf\x83\xe5\x85\xb3\xe4\xba\x8e\xe5\xbc\x80\xe5\xb1\x952020\xe5\xb9\xb4\xe5\xba\xa6\xe9\x93\xb6\xe8\xa1\x8c\xe9\x97\xb4\xe5\xa4\x96\xe6\xb1\x87\xe5\xb8\x82\xe5\x9c\xba\xe4\xbc\x98\xe7\xa7\x80\xe4\xba\xa4\xe6\x98\x93\xe4\xb8\xbb\xe7\xae\xa1\xe5\x92\x8c\xe4\xbc\x98\xe7\xa7\x80\xe4\xba\xa4\xe6\x98\x93\xe5\x91\x98\xe6\x8f\x90\xe5\x90\x8d\xe5\xb7\xa5\xe4\xbd\x9c\xe7\x9a\x84\xe9\x80\x9a\xe7\x9f\xa5(FBM-CLI-4-350095).doc'
print(s.encode('raw_unicode_escape').decode('utf-8'))
print(type(s))
print(type(s.encode('raw_unicode_escape')))
print(bytes(s.encode('raw_unicode_escape')))
print(s.encode('raw_unicode_escape'))
print(s.encode('raw_unicode_escape').decode('utf-8'))
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

【Python】汉字十六进制乱码问题的解决(Python2.7、3.7)
核心部分是:

s.encode('raw_unicode_escape').decode('utf-8')
  • 1

得到的是str类型的汉字

  • 我的微信
  • 这是我的微信扫一扫
  • weinxin
  • 我的微信公众号
  • 我的微信公众号扫一扫
  • weinxin