Requests-handling-timeouts
提供:Dev Guides
リクエスト-タイムアウトの処理
タイムアウトは、リクエストしているURLに簡単に追加できます。 たまたま、サードパーティのURLを使用していて、応答を待っています。 応答またはエラーでURLをタイムスパン内で応答させたい場合があるため、URLにタイムアウトを設定することは常に良い習慣です。 そうしないと、その要求を無期限に待機させる可能性があります。
以下の例に示すように、timeout paramを使用してURLにタイムアウトを与えることができ、値は秒単位で渡されます-
例
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.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)'))
与えられたタイムアウトは次のとおりです-
getdata =
requests.get('https://jsonplaceholder.typicode.com/users',timeout=0.001)
出力に示すように、実行により接続タイムアウトエラーがスローされます。 指定されたタイムアウトは0.001です。これは、要求が応答を取得してエラーをスローすることは不可能です。 ここで、タイムアウトを増やして確認します。
例
import requests
getdata =
requests.get('https://jsonplaceholder.typicode.com/users',timeout=1.000)
print(getdata.text)
出力
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"
}
}
]
1秒のタイムアウトで、要求されたURLに対する応答を取得できます。