生成url链接中诡异的百分号分割的中文编码

本文讲述了在Python爬虫中遇到的URL编码问题,特别是如何将GB2312编码的中文关键词转换为百分号分割的格式。在处理bilibili搜索链接时,成功将'羽生结弦'转换为'%E7%BE%BD%E7%94%9F%E7%BB%93%E5%BC%A6'。然而,在处理包含'西单'的关键词时,发现其使用的是GB2312、GBK或GB18030编码,通过编码查询网站转换并得到正确格式的百分号编码URL:%CE%F7%B5%A5。
摘要由CSDN通过智能技术生成

在之前的编程中爬取bilibili,

为了设置header中的referer,要将搜索链接中的关键词转为unicode中文编码,并且是百分号划分的格式。

 

https://search.bilibili.com/all?keyword=羽生结弦

变为

https://search.bilibili.com/all?keyword=%E7%BE%BD%E7%94%9F%E7%BB%93%E5%BC%A6

 

当时采用的方法是

from urllib import parse

headers = {'user-agent': 'Mozilla/5.0', 'referer': 'https://search.bilibili.com/all?keyword=' +
parse.quote(keyword, '')}

结果在爬取另一个网站中需要对中文编码的url时,出现了问题。

页面上查询关键词‘西单’后,出现的编码是 ‘%CE%F7%B5%A5’

通过编码查询网站ÿ

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值