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

本文详细介绍了如何使用Python的urllib模块发起POST请求,以爬取百度翻译的翻译结果为例,阐述了POST请求参数的封装、编码及转换过程,并提供了实际的代码示例。通过对关键字'kw'赋值为'苹果',成功发起POST请求并获取响应数据。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

urllib模块发起的POST请求

案例:爬取百度翻译的翻译结果

1.通过浏览器捉包工具,找到POST请求的url

针对ajax页面请求的所对应url获取,需要用到浏览器的捉包工具。查看百度翻译针对某个字条发送ajax请求,所对应的url

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

4ba12728512ff91ab7b39dbdd1c21720.png

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

f9d55646ce43b7e7a8a8c90282c6bae7.png

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

XHR代表 只显示抓到的基于ajax的POST请求

0bf6e9d52abab6f2d761bfb3d69555e5.png

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

565013f323615460751d95b5358ad2cb.png

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

e59a1c81dab9face3d606947ba5f55e1.png

发起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转中文

233be842118e3309a2ce91832750172e.png

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值