Python的requests库详细介绍

2024-08-30 20:44
文章标签 python 介绍 详细 requests

本文主要是介绍Python的requests库详细介绍,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Python requests 库是一个用于发送 HTTP 请求的简单而强大的库,它可以让你轻松地在 Python 中处理 HTTP 请求。这个库是 Python中处理 HTTP 请求的标准工具,因其简洁的 API 和强大的功能而广受欢迎。

1. 安装 requests

pip install requests

2. 基本用法

2.1 导入库

import requests

2.2 发送 GET 请求

GET 请求用于从服务器获取数据。最简单的方式是调用 requests.get() 方法。

response = requests.get('https://jsonplaceholder.typicode.com/posts/1')

2.3 发送 POST 请求

POST 请求用于向服务器发送数据。通常用于提交表单或上传数据。

response = requests.post('https://jsonplaceholder.typicode.com/posts', data={'title': 'foo', 'body': 'bar', 'userId': 1})

3. 请求参数

3.1 URL 参数

可以通过 params 参数向 URL 添加查询字符串参数。

params = {'key1': 'value1', 'key2': 'value2'}
response = requests.get('https://jsonplaceholder.typicode.com/posts', params=params)

这会生成 URL:https://jsonplaceholder.typicode.com/posts?key1=value1&key2=value2

3.2 请求头

使用 headers 参数自定义请求头。

headers = {'User-Agent': 'my-app/0.0.1'}
response = requests.get('https://jsonplaceholder.typicode.com/posts', headers=headers)

3.3 POST 请求中的数据

对于 POST 请求,可以通过 data 或 json 参数发送数据。

  • data 参数用于发送表单数据(application/x-www-form-urlencoded 格式):
response = requests.post('https://jsonplaceholder.typicode.com/posts', data={'key': 'value'})
  • json 参数用于发送 JSON 格式的数据:
response = requests.post('https://jsonplaceholder.typicode.com/posts', json={'key': 'value'})

3.4 上传文件

可以使用 files 参数上传文件。

files = {'file': open('report.txt', 'rb')}
response = requests.post('https://jsonplaceholder.typicode.com/upload', files=files)

4. 响应处理

requests 库返回的 response 对象包含了服务器响应的所有信息。

4.1 访问响应内容

  • 文本内容:使用 response.text 获取响应的文本内容。
print(response.text)
  • JSON 内容:使用 response.json() 解析 JSON 响应。
json_data = response.json()
  • 二进制内容:使用 response.content 获取二进制内容(如图片、文件)。
with open('image.png', 'wb') as f:f.write(response.content)

4.2 访问响应状态

  • 状态码:response.status_code 返回 HTTP 状态码。
if response.status_code == 200:print('Success!')
else:print('Error:', response.status_code)
  • 响应头:response.headers 返回响应头信息。
print(response.headers)

5. 超时和重试

5.1 超时设置

通过 timeout 参数设置请求的超时时间(单位:秒)。

response = requests.get('https://jsonplaceholder.typicode.com/posts', timeout=5)

5.2 请求重试

requests 库没有内建的重试机制,但可以通过 requests.adapters.HTTPAdapter 实现自动重试。

from requests.adapters import HTTPAdapter
from requests.packages.urllib3.util.retry import Retrysession = requests.Session()
retries = Retry(total=5, backoff_factor=0.1, status_forcelist=[500, 502, 503, 504])
adapter = HTTPAdapter(max_retries=retries)
session.mount('http://', adapter)
session.mount('https://', adapter)response = session.get('https://jsonplaceholder.typicode.com/posts')

6. 会话对象

使用 requests.Session() 可以在多次请求之间共享会话信息(如 Cookies、headers)。

session = requests.Session()
session.get('https://jsonplaceholder.typicode.com/cookies/set/sessioncookie/123456789')
response = session.get('https://jsonplaceholder.typicode.com/cookies')

7. 身份验证

7.1 基本身份验证

可以通过 auth 参数进行基本身份验证。

from requests.auth import HTTPBasicAuth
response = requests.get('https://jsonplaceholder.typicode.com/basic-auth/user/pass', auth=HTTPBasicAuth('user', 'pass'))

7.2 Token 身份验证

对于 Token 验证,可以在请求头中添加 Authorization

headers = {'Authorization': 'Bearer YOUR_ACCESS_TOKEN'}
response = requests.get('https://jsonplaceholder.typicode.com/protected', headers=headers)

8. 代理支持

使用 proxies 参数可以为请求设置代理。

proxies = {'http': 'http://10.10.1.10:3128','https': 'http://10.10.1.10:1080',
}
response = requests.get('https://jsonplaceholder.typicode.com', proxies=proxies)

9. SSL 证书验证

requests 默认会验证 SSL 证书。可以通过 verify 参数禁用证书验证(不推荐)。

response = requests.get('https://jsonplaceholder.typicode.com', verify=False)

10. 流式请求

对于大文件,可以使用流式请求来逐步读取响应数据。

response = requests.get('https://jsonplaceholder.typicode.com/large-file', stream=True)
with open('large_file.zip', 'wb') as f:for chunk in response.iter_content(chunk_size=8192):if chunk:f.write(chunk)

11. 错误处理

requests 库会在遇到某些严重错误时抛出异常,如连接失败、超时等。常见的异常包括:

  • requests.exceptions.RequestException
  • requests.exceptions.HTTPError
  • requests.exceptions.ConnectionError
  • requests.exceptions.Timeout
    可以通过 try-except 结构来捕获这些异常并进行处理。
try:response = requests.get('https://jsonplaceholder.typicode.com/posts')response.raise_for_status()
except requests.exceptions.HTTPError as errh:print ("Http Error:", errh)
except requests.exceptions.ConnectionError as errc:print ("Error Connecting:", errc)
except requests.exceptions.Timeout as errt:print ("Timeout Error:", errt)
except requests.exceptions.RequestException as err:print ("OOps: Something Else", err)

12. 自定义适配器

可以创建自定义适配器以实现更复杂的请求行为。例如,实现特定的重试逻辑或日志记录。

总结

requests 库是一种简洁、强大且易于使用的工具,用于处理 HTTP 请求。无论是基本的 GETPOST 请求,还是复杂的身份验证、会话保持和流式处理,requests 都能够很好地胜任。如果你经常处理 HTTP 请求,那么熟练掌握 requests 库将大大提高你的开发效率。

这篇关于Python的requests库详细介绍的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1121880

相关文章

Java使用Curator进行ZooKeeper操作的详细教程

《Java使用Curator进行ZooKeeper操作的详细教程》ApacheCurator是一个基于ZooKeeper的Java客户端库,它极大地简化了使用ZooKeeper的开发工作,在分布式系统... 目录1、简述2、核心功能2.1 CuratorFramework2.2 Recipes3、示例实践3

Python如何使用__slots__实现节省内存和性能优化

《Python如何使用__slots__实现节省内存和性能优化》你有想过,一个小小的__slots__能让你的Python类内存消耗直接减半吗,没错,今天咱们要聊的就是这个让人眼前一亮的技巧,感兴趣的... 目录背景:内存吃得满满的类__slots__:你的内存管理小助手举个大概的例子:看看效果如何?1.

Python+PyQt5实现多屏幕协同播放功能

《Python+PyQt5实现多屏幕协同播放功能》在现代会议展示、数字广告、展览展示等场景中,多屏幕协同播放已成为刚需,下面我们就来看看如何利用Python和PyQt5开发一套功能强大的跨屏播控系统吧... 目录一、项目概述:突破传统播放限制二、核心技术解析2.1 多屏管理机制2.2 播放引擎设计2.3 专

Python中随机休眠技术原理与应用详解

《Python中随机休眠技术原理与应用详解》在编程中,让程序暂停执行特定时间是常见需求,当需要引入不确定性时,随机休眠就成为关键技巧,下面我们就来看看Python中随机休眠技术的具体实现与应用吧... 目录引言一、实现原理与基础方法1.1 核心函数解析1.2 基础实现模板1.3 整数版实现二、典型应用场景2

Python实现无痛修改第三方库源码的方法详解

《Python实现无痛修改第三方库源码的方法详解》很多时候,我们下载的第三方库是不会有需求不满足的情况,但也有极少的情况,第三方库没有兼顾到需求,本文将介绍几个修改源码的操作,大家可以根据需求进行选择... 目录需求不符合模拟示例 1. 修改源文件2. 继承修改3. 猴子补丁4. 追踪局部变量需求不符合很

python+opencv处理颜色之将目标颜色转换实例代码

《python+opencv处理颜色之将目标颜色转换实例代码》OpenCV是一个的跨平台计算机视觉库,可以运行在Linux、Windows和MacOS操作系统上,:本文主要介绍python+ope... 目录下面是代码+ 效果 + 解释转HSV: 关于颜色总是要转HSV的掩膜再标注总结 目标:将红色的部分滤

Python 中的异步与同步深度解析(实践记录)

《Python中的异步与同步深度解析(实践记录)》在Python编程世界里,异步和同步的概念是理解程序执行流程和性能优化的关键,这篇文章将带你深入了解它们的差异,以及阻塞和非阻塞的特性,同时通过实际... 目录python中的异步与同步:深度解析与实践异步与同步的定义异步同步阻塞与非阻塞的概念阻塞非阻塞同步

Python Dash框架在数据可视化仪表板中的应用与实践记录

《PythonDash框架在数据可视化仪表板中的应用与实践记录》Python的PlotlyDash库提供了一种简便且强大的方式来构建和展示互动式数据仪表板,本篇文章将深入探讨如何使用Dash设计一... 目录python Dash框架在数据可视化仪表板中的应用与实践1. 什么是Plotly Dash?1.1

在C#中调用Python代码的两种实现方式

《在C#中调用Python代码的两种实现方式》:本文主要介绍在C#中调用Python代码的两种实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录C#调用python代码的方式1. 使用 Python.NET2. 使用外部进程调用 Python 脚本总结C#调

Python下载Pandas包的步骤

《Python下载Pandas包的步骤》:本文主要介绍Python下载Pandas包的步骤,在python中安装pandas库,我采取的方法是用PIP的方法在Python目标位置进行安装,本文给大... 目录安装步骤1、首先找到我们安装python的目录2、使用命令行到Python安装目录下3、我们回到Py