请求 - 处理错误
本章将探讨如何处理使用 HTTP 请求库时出现的错误。对于所有可能的情况进行错误管理始终是一种好习惯。
错误异常
请求模块提供以下类型的错误异常 -
ConnectionError - 当出现任何连接错误时,将引发该异常。例如,网络故障、DNS 错误,因此 Request 库将引发 ConnectionError 异常。
Response.raise_for_status() - 根据状态代码(即 401、404),它会为请求的 URL 引发 HTTPError。
HTTPError - 该错误将针对请求提出的无效响应引发。
超时 - 为请求的 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)'))
广告