
- 請求教程
- 請求 - 首頁
- 請求 - 概述
- 請求 - 環境設定
- 請求 - 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 的響應。
廣告