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

【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类型的汉字

  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python中可以通过内置函数hex()将整数转换为十六进制字符串,也可以通过int()函数将十六进制字符串转换为整数。同时,也可以通过自定义函数实现字符串转十六进制十六进制转字符串的操作。 以下是Python中字符串转十六进制十六进制转字符串的自定义函数: 1.字符串转十六进制 ```python def to_hex(string): ''' 字符串转十六进制 ''' hex_string = [] # 初始化转换后的十六进制字符列表。 for i in string: # 遍历字符串。 hex_string.append(hex(ord(i))[2:].zfill(4).upper()) # 用“切片”[:3]方式截取转换后的十六进制字符串除十六进制标识字符外的字符串。由于有的中文字符需四位十六进制字符表示,所以用str.zfill(4)设置成每个字符四位十六进制字符(不足四位前置0)。为了好看,我用str.upper()方法转小写字母为大写。 return ''.join(hex_string) # 返回“无缝链接”后的十六进制字符串。 ``` 2.十六进制转字符串 ```python def to_string(hex_string): ''' 十六进制转字符串 ''' string = '' # 初始化转换后的字符串。 for i in range(0, len(hex_string), 4): # 每四位十六进制字符为一个字符。 string += chr(int(hex_string[i:i+4], 16)) # 将四位十六进制字符转换为整数,再将整数转换为字符。 return string # 返回转换后的字符串。 ``` 使用示例: ```python # 字符串转十六进制 string = 'hello world' hex_string = to_hex(string) print(hex_string) # 输出:48656C4C4F20576F726C64 # 十六进制转字符串 string = to_string(hex_string) print(string) # 输出:hello world ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值