请求 - 处理错误



本章将探讨如何处理使用 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)'))   
广告