Requests-working-with-errors

提供:Dev Guides
移動先:案内検索

リクエスト-エラーの処理

この章では、Httpリクエストライブラリを使用するときに発生するエラーに対処する方法について説明します。 考えられるすべてのケースでエラーを管理することは常に良い習慣です。

エラー例外

要求モジュールは、次のタイプのエラー例外を提供します-

*ConnectionError* -接続エラーがある場合、これが発生します。 たとえば、ネットワークが失敗した、DNSエラーが発生したため、リクエストライブラリは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)'))