- 請求教程
- 請求 - 首頁
- 請求 - 概述
- 請求 - 環境設定
- 請求 - HTTP 請求的工作原理?
- 請求 - 使用請求
- 處理 HTTP 請求的響應
- 請求 - HTTP 請求頭
- 請求 - 處理 GET 請求
- 處理 POST、PUT、PATCH 和 DELETE 請求
- 請求 - 檔案上傳
- 請求 - 使用 Cookie
- 請求 - 處理錯誤
- 請求 - 處理超時
- 請求 - 處理重定向
- 請求 - 處理歷史記錄
- 請求 - 處理會話
- 請求 - SSL 認證
- 請求 - 身份驗證
- 請求 - 事件掛鉤
- 請求 - 代理
- 請求 - 使用請求進行網路抓取
- 請求 - 有用資源
- 請求 - 快速指南
- 請求 - 有用資源
- 請求 - 探討
請求 - 處理超時
超時可以輕鬆新增到要請求的 URL。具體來說,您正在使用第三方 URL 並等待響應。最好對 URL 設定超時,因為我們可能希望 URL 在某個時間範圍內用響應或錯誤進行響應。如果不這樣做,可能會導致無限期地等待該請求。
我們可以使用 timeout 引數對 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": "Sincere@april.biz",
"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 的響應。
廣告