python爬取内容乱码_Python爬取网站返回的内容为乱码解决方法

1、爬取某网站内容时,返回的结果为乱码,如图:

d62b881ddcdf0ac0700d789f7893d9e6.png

2、写在前面的解释

Requests会基于HTTP头部响应的编码做出有根据的推测,当访问r.text时,Requests会使用其推测的文本编码。

查看网页返回的字符集类型:r.apparent_encoding

查看自动判断的字符集类型:r.encoding

37c0eeb0444568266860feb8b1419c57.png

可以看到Requests推测的文本编码(ISO-8859-1)与源网页编码(utf-8) 不一致,因此会导致乱码问题的出现。

注:源网页也能直接查看编码格式,如下图:

241e7cd2d97811e90b56ae526ffe3218.png

3、解决方法

这里要注意顺序,需要先指定r.encoding的编码格式,再访问r.text。即第9行代码必须写在第10行代码之前。

(1)方法一:直接指定r.encoding为源网页的编码格式

r.encoding="utf-8"

c6afcf6758b0536b82fcbd32ed039e6e.png

(2)方法二:通过r.apparent_encoding属性来指定,直接将其值赋给r.encoding

r.encoding = r.apparent_encoding

4fda7f3906d73ef1ec29a12ad0e8d0e3.png

(3)方法三:通过编码、解码的方式

11f32c11f0a47db61faa6330bf4b5372.png

4、乱码问题解决

576772c8eae4ba99599fd0218a9e7387.png

--------结束----------

  • 2
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python爬取数据时出现乱码问题是比较常见的情况。处理乱码问题有几种方法,具体取决于使用的爬虫框架和编码方式。 一种常见的处理乱码问题的方法是使用response对象的encoding属性来指定编码方式。例如,可以使用response.encoding = 'utf-8'来将编码方式设置为UTF-8。然后可以使用response.text来获取解码后的文本内容。 另一种方法是使用response.content来获取原始的字节数据,然后使用decode()方法将其解码为字符串。例如,可以使用response.content.decode('utf-8')来将字节数据解码为UTF-8编码的字符串。 此外,还可以使用response.apparent_encoding来获取响应内容的推测编码方式。这个方法会根据响应内容自动推测编码方式,比较准确。可以使用response.content.decode(response.apparent_encoding)来解码内容。 在将爬取到的数据保存到本地时,需要注意使用正确的编码方式。可以使用open函数的encoding参数来指定编码方式。例如,可以使用open(sourcePath, 'w', encoding='utf-8')来以UTF-8编码方式打开文件并写入内容。 总之,处理乱码问题需要根据具体情况选择合适的方法和编码方式。可以根据响应对象的encoding属性、apparent_encoding属性以及使用decode()方法来解码数据,并在保存到本地时使用正确的编码方式。 #### 引用[.reference_title] - *1* *3* [python爬虫乱码解决方案](https://blog.csdn.net/wanbianip/article/details/108623413)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [Python:爬虫乱码](https://blog.csdn.net/weixin_45068714/article/details/127293500)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值