İstekler - Hatalarla Çalışma

Bu bölümde, Http istek kitaplığıyla çalışırken ortaya çıkan hataların nasıl ele alınacağı tartışılacaktır. Olası tüm durumlar için hataların yönetilmesi her zaman iyi bir uygulamadır.

Hata İstisnası

İstekler modülü aşağıdaki hata istisnası türlerini verir -

ConnectionError- Herhangi bir bağlantı hatası varsa bu yükseltilecektir. Örneğin, ağ başarısız oldu, DNS hatası, bu nedenle İstek kitaplığı ConnectionError istisnasını artıracaktır.

Response.raise_for_status() - 401, 404 gibi durum koduna bağlı olarak, istenen url için HTTPError yükseltir.

HTTPError - Bu hata, yapılan istek için geçersiz bir yanıt gelmesi durumunda ortaya çıkacaktır.

Timeout - İstenen URL için zaman aşımı nedeniyle oluşan hatalar.

TooManyRedirects - Maksimum yeniden yönlendirme için sınır aşılırsa, TooManyRedirects hatası ortaya çıkar.

Misal

İşte zaman aşımı için gösterilen hatalara bir örnek -

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

Çıktı

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