Żądania - praca z błędami

W tym rozdziale omówimy, jak radzić sobie z błędami pojawiającymi się podczas pracy z biblioteką żądań HTTP. Zawsze dobrze jest zarządzać błędami we wszystkich możliwych przypadkach.

Wyjątek błędu

Moduł żądań podaje następujące typy wyjątków błędów -

ConnectionError- To zostanie podniesione, jeśli wystąpi jakikolwiek błąd połączenia. Na przykład niepowodzenie sieci, błąd DNS, więc biblioteka Request zgłosi wyjątek ConnectionError.

Response.raise_for_status() - Na podstawie kodu statusu, tj. 401, 404, zgłosi błąd HTTPError dla żądanego adresu URL.

HTTPError - Ten błąd zostanie zgłoszony w przypadku nieprawidłowej odpowiedzi przychodzącej na wysłane żądanie.

Timeout - Błędy zgłoszone z powodu przekroczenia limitu czasu dla żądanego adresu URL.

TooManyRedirects - Jeśli limit zostanie przekroczony dla maksymalnej liczby przekierowań, spowoduje to błąd TooManyRedirects.

Przykład

Oto przykład błędów wyświetlanych po przekroczeniu limitu czasu -

import requests
getdata = 
requests.get('https://jsonplaceholder.typicode.com/users',timeout=0.001)
print(getdata.text)

Wynik

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)'))