- 请求教程
- 请求 - 主页
- 请求 - 概述
- 请求 - 环境设置
- 请求 - Http 请求如何工作?
- 请求 - 处理请求
- 处理 HTTP 请求的响应
- 请求 - HTTP 请求标头
- 请求 - 处理 GET 请求
- 处理 POST、PUT、PATCH 和 DELETE 请求
- 请求 - 文件上传
- 请求 - 使用 Cookie
- 请求 - 处理错误
- 请求 - 处理超时
- 请求 - 处理重定向
- 请求 - 处理历史记录
- 请求 - 处理会话
- 请求 - SSL 认证
- 请求 - 身份验证
- 请求 - 事件挂钩
- 请求 - 代理
- 请求 - 使用请求进行网页抓取
- 请求有用的资源
- 请求 - 快速指南
- 请求 - 有用的资源
- 请求 - 讨论
请求 - 处理错误
本章将讨论如何处理使用 Http 请求库时出现的错误。对所有可能的情况进行错误管理始终是一个好习惯。
错误异常
请求模块给出以下类型的错误异常 -
ConnectionError - 如果存在任何连接错误,则会引发此错误。例如,网络失败、DNS 错误等,Request 库会引发 ConnectionError 异常。
Response.raise_for_status() - 基于状态代码,即 401、404,它将针对请求的 url 引发 HTTPError。
HTTPError - 对于所发出的请求的无效响应将引发此错误。
Timeout - 因请求的 URL 超时而引发的错误。
TooManyRedirects - 如果超过最大重定向限制,则会引发 TooManyRedirects 错误。
例子
以下是超时错误的示例 -
import requests getdata = requests.get('https://jsonplaceholder.typicode.com/users',timeout=0.001) print(getdata.text)
输出
raise ConnectTimeout(e, request=request) requests.exceptions.ConnectTimeout: HTTPSConnectionPool(host='jsonplaceholder.ty picode.com', port=443): Max retries exceeded with url: /users (Caused by Connect TimeoutError(<urllib3.connection.VerifiedHTTPSConnection object at 0x000000B02AD E76A0>, 'Connection to jsonplaceholder.typicode.com timed out. (connect timeout = 0.001)'))