网页数据爬取中文乱码处理--编码问题

自学爬虫有一段时间了,期间总是觉得内容编码会傻傻分不清楚,尤其是直接网页拿数据的时候,遇见中文有时候特别麻烦,看大神介绍的东西太多,只记下了处理方式,仅供参考,不对地方欢迎大家指正~~


一般请求返回内容编码方式步骤如下:

1、查看数据源网页的编码形式--爬取数据所在网页源代码就有写:


2、编码解析:

respond.decode(请求返回的编码格式).encode(Python默认的utf-8)

笔记中其他大神这样教,实践中大多情况我都用:respond.encode(Python默认的utf-8).decode(请求返回的编码格式)


爬取网页内容正常编译,无报错,英文均显示正常,中文乱码

最近爬取免费取名网站时候,遇见爬下来的编码正确编码后无报错,英文均显示正常,但是中文奇奇怪怪乱码情况如下图,网页编码两种情况遇见解析后如此,处理方法如下,


第一种:网页编码为gb2312 (requests的get方式获取数据)

原来处理方式(出现上图乱码),响应内容=respond.text.encode('utf-8').decode('gb2312')×

改进处理方式:     respond.content.decode('gb18030','ignore') ---亲试遇见中文响应内容解析还是用这种方式好

                            respond.content.decode('gbk','ignore')

                             #使用gbk2312出现报错'gbk' codec can't encode character '\u30fb' in position 12530: illegal multibyte sequence~ 这是一个很尴尬的问题,第二种第一次处理也报错,后面又可以了~~~

总结:遇见中文编码decode里面,'gbk'/'gbk2312'/'gb18030' (备用繁体编码选项没用过,可以留用'big5'/'big5hkscs')总有一款适合你 实在不行看下面↓↓↓

第二种:网页编码为utf-8 (requests的get方式获取数据)

尝试了上面n中组合形式,就是顽固的不行,终于借鉴了一些大神的方法解决掉了,decode('utf-8')确定无疑。

解决乱码:在代码之前添加默认设置编码格式

sys.stdout = io.TextIOWrapper(sys.stdout.buffer,encoding='gb18030')
url = 'https://www.yw11.com/html/qiming/xuename/2009/0929/273.html'
urlcontent = requests.get(url).content.decode('utf-8')

  • 16
    点赞
  • 49
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
在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 ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值