Żądania - obsługa limitów czasu

Limity czasu można łatwo dodać do żądanego adresu URL. Tak się składa, że ​​używasz zewnętrznego adresu URL i czekasz na odpowiedź. Dobrą praktyką jest zawsze pozostawienie limitu czasu w adresie URL, ponieważ możemy chcieć, aby adres URL odpowiadał w określonym czasie z odpowiedzią lub błędem. Nie zrobienie tego może spowodować oczekiwanie na to żądanie w nieskończoność.

Możemy nadać adresowi URL limit czasu, używając parametru limitu czasu, a wartość jest przekazywana w sekundach, jak pokazano w poniższym przykładzie -

Przykład

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

Podany limit czasu jest następujący -

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

Wykonanie zgłasza błąd przekroczenia limitu czasu połączenia, jak pokazano w danych wyjściowych. Podany limit czasu wynosi 0,001, co nie jest możliwe, aby żądanie odzyskało odpowiedź i zgłasza błąd. Teraz zwiększymy limit czasu i sprawdzimy.

Przykład

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

Wynik

E:\prequests>python makeRequest.py
[
   {
      "id": 1,
      "name": "Leanne Graham",
      "username": "Bret",
      "email": "[email protected]",
      "address": {
         "street": "Kulas Light",
         "suite": "Apt. 556",
         "city": "Gwenborough",
         "zipcode": "92998-3874",
         "geo": {
            "lat": "-37.3159",
            "lng": "81.1496"
         }
      },
      "phone": "1-770-736-8031 x56442",
      "website": "hildegard.org",
      "company": {
         "name": "Romaguera-Crona",
         "catchPhrase": "Multi-layered client-server neural-net",
         "bs": "harness real-time e-markets"
      }
   }
]

Z limitem czasu wynoszącym 1 sekundę możemy uzyskać odpowiedź na żądany adres URL.