微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

python爬虫 urllib模块发起post请求过程解析

urllib模块发起的POST请求

案例:爬取百度翻译的翻译结果
1.通过浏览器捉包工具,找到POST请求的url
针对ajax页面请求的所对应url获取,需要用到浏览器的捉包工具。查看百度翻译针对某个字条发送ajax请求,所对应的url

点击clear按钮可以把抓包工具,所抓到请求清空

在这里插入图片描述


然后填上翻译字条发送ajax请求,红色框住的都是发送的ajax请求

@H_404_19@


抓包工具All按钮代表 显示抓到的所有请求 ,包括GET、POST请求 、基于ajax的POST请求
XHR代表 只显示抓到的基于ajax的POST请求

在这里插入图片描述


哪个才是我们所要的基于ajax的POST请求,这个POST请求是携带翻译字条的苹果请求参数

在这里插入图片描述


再看看这个POST请求 对应的请求URL ,这个URL是我们要请求的URL

在这里插入图片描述


发起POST请求之前,要处理POST请求携带的参数 3步流程:
一、将POST请求封装到字典
二、使用parse模块中的urlencode(返回值类型是字符串类型)进行编码处理
三、将步骤二的编码结果转换成byte类型

import urllib.request
import urllib.parse
# 1.指定url
url = 'https://fanyi.baidu.com/sug'
# 发起POST请求之前,要处理POST请求携带的参数 流程:
# 一、将POST请求封装到字典
data = {
  # 将POST请求所有携带参数放到字典中
  'kw':'苹果',
}
# 二、使用parse模块中的urlencode(返回值类型是字符串类型)进行编码处理
data = urllib.parse.urlencode(data)
 
# 三、将步骤二的编码结果转换成byte类型
data = data.encode()
 
'''2. 发起POST请求:urlopen函数的data参数表示的就是经过处理之后的
POST请求携带的参数
'''
response = urllib.request.urlopen(url=url,data=data)
 
data = response.read()
print(data)

把拿到的翻译结果 去json在线格式校验(在线json校验格式化工具(Be JSON)),

点击格式化校验和unicode转中文

在这里插入图片描述

推荐我们的python学习基地,点击进入看老程序是如何学习的!从基础的python脚本、爬虫、django、数据挖掘等编程技术,工作经验,还有前辈精心为学习python的小伙伴整理零基础到项目实战的资料,!每天都有程序员定时讲解Python技术,分享一些学习的方法和需要留意的小细节
以上就是本文的全部内容,希望对大家的学习有所帮助

在这里插入图片描述

进阶程序员阿福 发布了13 篇原创文章 · 获赞 1 · 访问量 4814 私信 关注

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐