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

本文探讨了在Python 2.7中遇到的乱码问题,重点讲解如何将str类型的unicode编码字符串正确转换为可读的汉字形式,包括使用`bytes()`函数和`encode('utf-8')`方法,并提供了解决方法和示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

【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'
  • 首先,通过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))

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

s.encode('utf-8')

此时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'))

在这里插入图片描述
核心部分是:

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

得到的是str类型的汉字

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值