- 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
核心部分是:
s.encode('raw_unicode_escape').decode('utf-8')
- 1
得到的是str类型的汉字
- 我的微信
- 这是我的微信扫一扫
- 我的微信公众号
- 我的微信公众号扫一扫