Python3之乱码\\xe6\\x97\\xa0\\xe6\\xb3\\x95处理方式

作者:Quincy379 时间:2021-03-30 10:19:47 

查看字符编码:


import chardet
response = chardet.detect(b'\xe5\xbd\x93\xe5\x89\x8d\xe7\x9b\xae\xe5\xbd\x95\xe4\xb8\x8b\xe6\x89\x80\xe6\x9c\x89\xe6\x96\x87\xe4\xbb\xb6\xe5\x90\x8d\xe6\xb1\x87\xe6\x80\xbb\xe5\x88\x97\xe8\xa1\xa8')
print(response)

{'encoding': 'utf-8', 'confidence': 0.99, 'language': ''}

乱码字符转换:


response = b'\xe5\xbd\x93\xe5\x89\x8d\xe7\x9b\xae\xe5\xbd\x95\xe4\xb8\x8b\xe6\x89\x80\xe6\x9c\x89\xe6\x96\x87\xe4\xbb\xb6\xe5\x90\x8d\xe6\xb1\x87\xe6\x80\xbb\xe5\x88\x97\xe8\xa1\xa8'
print(response.decode('utf8'))

# def decode_char(*args):
#   response = args[0]
#   print(response.decode('utf8'))
#
# c = b'\a8\xe5\x90\xa7\xef\xbc\x81'
#
# decode_char(c)

补充知识:python3 中怎么把类似这样的'\xe5\xae\x9d\xe9\xb8\xa1\xe5\xb8\x82'转换成汉字输出

在编程的过程中遇到了类似的困扰,网上查了很多解决思路,终于算是明白了一些,这里和大家分享 一下。

python3相对于python2最重要的新特性之一就是对字符串(文本)和二进制数据流做了明确的区分,文本总是Unicode,由字符类型表示,而二进制数据则由bytes类型表示,python3不会以任意隐式方式混用字节型和字符型,也不能拼接字符串和字节流(python2中可以,会自动进行转换),也不能在字节流中搜索字符串,也不能将字符串传入参数为字节流的函数。

str和bytes类型之间的相互转换

字符串类str有一个encode()方法,它是字符串向比特流的编码过程。

bytes类则有一个decode()方法,它是比特流向字符串的解码过程

Python3之乱码\\xe6\\x97\\xa0\\xe6\\xb3\\x95处理方式

encode过程


s = '绝地求生'
ss = s.encode()
print(type(ss))
print(ss)

运行结果:

Python3之乱码\\xe6\\x97\\xa0\\xe6\\xb3\\x95处理方式

decode过程


s = b'\xe7\xbb\x9d\xe5\x9c\xb0\xe6\xb1\x82\xe7\x94\x9f'
ss = s.decode()
print(type(ss))
print(ss)

运行结果:

Python3之乱码\\xe6\\x97\\xa0\\xe6\\xb3\\x95处理方式

了解过基本的转化过程,下面回到主题,如何将'\xe7\xbb\x9d\xe5\x9c\xb0\xe6\xb1\x82\xe7\x94\x9f'转换成汉字输出呢?

要解决的问题是将bytes类型的内容以汉字的形式输出,但是该部分内容是字符串类型。因此首先需要将该str转换成bytes类型,再decode解码为str输出。这里需要用到的方法是encode(‘raw_unicode_escape')。当然,也可以使用decode(‘raw_unicode_escape')方法输出内容为bytes形式的字符串


s = '\xe7\xbb\x9d\xe5\x9c\xb0\xe6\xb1\x82\xe7\x94\x9f'
ss = s.encode('raw_unicode_escape')
print(type(ss))
print(ss)

sss = ss.decode()
print(sss)

结果:

Python3之乱码\\xe6\\x97\\xa0\\xe6\\xb3\\x95处理方式

方法补充:如果我们直接定义bytes类型的变量,也可以直接使用str(s, ‘utf8')的方式输出汉字


s = b'\xe7\xbb\x9d\xe5\x9c\xb0\xe6\xb1\x82\xe7\x94\x9f'

print(type(s))
print(s)

ss = str(s, 'utf8')
print(ss)

结果:

Python3之乱码\\xe6\\x97\\xa0\\xe6\\xb3\\x95处理方式

第二种方法可以输出从网络上直接抓取的网页中包含的中文字符。

我们使用如下代码,抓取网页www.baidu.com。


import urllib.request
response = urllib.request.urlopen('http://www.baidu.com')
html = response.read()
print(html)

显示的结果中,中文部分会以\xe7\x99\xbe\xe5\xba\xa6\xe4\xb8\x80代替,这里可以使用方法二进行转换。


import urllib.request
response = urllib.request.urlopen('http://www.baidu.com')
html =str(response.read(),'utf-8')
print(html)

结果如下:

Python3之乱码\\xe6\\x97\\xa0\\xe6\\xb3\\x95处理方式

来源:https://blog.csdn.net/qq_33733970/article/details/80374614

标签:Python3,乱码
0
投稿

猜你喜欢

  • Python迭代器定义与简单用法分析

    2022-10-24 02:44:29
  • SELECT… FOR UPDATE 排他锁的实现

    2024-01-19 12:30:16
  • Python学习之装饰器与类的装饰器详解

    2023-11-23 20:04:07
  • Python调用API接口实现人脸识别

    2022-09-10 22:42:20
  • 增删改查sql语法基础教程

    2024-01-16 23:42:18
  • 跟我学习javascript的闭包

    2024-04-23 09:11:51
  • Python Gitlab Api 使用方法

    2021-03-11 16:30:11
  • opencv python 图片读取与显示图片窗口未响应问题的解决

    2021-05-15 22:08:53
  • 分析运行中的 Python 进程详细解析

    2021-09-19 14:47:30
  • Sql中将datetime转换成字符串的方法(CONVERT)

    2024-01-22 10:25:59
  • pygame可视化幸运大转盘实现

    2021-03-01 05:22:11
  • SQLSERVER查看数据库日志方法与语句示例代码(已亲测)

    2024-01-17 21:32:35
  • SQL Server数据库入门学习总结

    2024-01-21 18:23:25
  • 指定区域的图片自动按比例缩小的js代码(防止页面被图片撑破)

    2024-04-17 10:05:21
  • 用实例说明python的*args和**kwargs用法

    2021-05-04 08:25:55
  • Python Flask 转换器的使用详解

    2023-06-30 15:42:09
  • 详解auto-vue-file:一个自动创建vue组件的包

    2024-05-11 09:11:32
  • SQL Server SQL Agent服务使用教程小结

    2024-01-25 20:35:13
  • Python3中str、bytes、bytearray转化

    2023-01-11 23:29:30
  • Python+matplotlib实现绘制等高线图示例详解

    2022-09-18 05:44:11
  • asp之家 网络编程 m.aspxhome.com