亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Python中Requests庫(kù)的實(shí)現(xiàn)示例

 更新時(shí)間:2025年05月19日 10:32:13   作者:wanglaqqqq  
Requests是Python生態(tài)中最廣泛使用的HTTP客戶端庫(kù),本文主要介紹了Python中Requests庫(kù)的實(shí)現(xiàn)示例,具有一定的參考價(jià)值,感興趣的可以了解一下

一、Requests 庫(kù)簡(jiǎn)介

Requests 是 Python 生態(tài)中 ?最廣泛使用的 HTTP 客戶端庫(kù),以「人類友好」為核心設(shè)計(jì)理念,簡(jiǎn)化了 HTTP 協(xié)議交互的復(fù)雜性。其核心價(jià)值包括:

  • ?極簡(jiǎn) API:通過 requests.get()post() 等函數(shù)實(shí)現(xiàn)復(fù)雜網(wǎng)絡(luò)操作,代碼量比原生 urllib 減少 70% 以上。
  • ?全協(xié)議支持:覆蓋 GET、POST、PUT、DELETE 等主流 HTTP 方法,適配 RESTful API、WebSocket 等場(chǎng)景。
  • ?高效穩(wěn)定:內(nèi)置連接池復(fù)用、自動(dòng)重試、超時(shí)控制等機(jī)制,支持每秒 1000+ 次高并發(fā)請(qǐng)求。
  • ?生態(tài)兼容:無縫對(duì)接 BeautifulSoup(網(wǎng)頁(yè)解析)、Pandas(數(shù)據(jù)處理)、Flask(服務(wù)測(cè)試)等工具鏈。

二、安裝與環(huán)境配置

# 基礎(chǔ)安裝(Python 3.7+ 環(huán)境)  
pip install requests  

# 國(guó)內(nèi)鏡像加速安裝  
pip install -i https://pypi.tuna.tsinghua.edu.cn/simple requests  

驗(yàn)證安裝

import requests  
print(requests.__version__)  # 輸出示例:2.31.0  

三、核心功能與常用函數(shù)

?1. HTTP 基礎(chǔ)請(qǐng)求方法

函數(shù)功能描述示例代碼
?**requests.get()**發(fā)送 GET 請(qǐng)求(數(shù)據(jù)獲取場(chǎng)景)response = requests.get("https://api.github.com")
?**requests.post()**發(fā)送 POST 請(qǐng)求(表單提交/API 調(diào)用)requests.post("https://httpbin.org/post", data={"key": "value"})
?**requests.put()**發(fā)送 PUT 請(qǐng)求(資源更新)requests.put("https://api.example.com/data/1", json={"name": "Kimi"})
?**requests.delete()**發(fā)送 DELETE 請(qǐng)求(資源刪除)requests.delete("https://api.example.com/data/1")
?**requests.Session()**創(chuàng)建會(huì)話對(duì)象(保持 Cookies 和 TCP 連接復(fù)用,提升性能)with requests.Session() as s: s.get("https://example.com")

2. 請(qǐng)求參數(shù)與定制化

  • ?查詢參數(shù)傳遞

    params = {"q": "Python", "page": 2}  
    response = requests.get("https://search.example.com", params=params)  

    生成 URL:https://search.example.com?q=Python&page=2 

  • ?請(qǐng)求頭定制

    headers = {"User-Agent": "Mozilla/5.0", "Authorization": "Bearer YOUR_TOKEN"}  
    requests.get("https://api.example.com", headers=headers)  

    模擬瀏覽器行為或身份驗(yàn)證 

  • ?JSON 數(shù)據(jù)提交

    requests.post("https://api.example.com/login", json={"username": "admin", "password": "secret"})  

    自動(dòng)設(shè)置 Content-Type: application/json 

?3. 響應(yīng)處理與解析

屬性/方法功能描述示例代碼
?**response.status_code**獲取 HTTP 狀態(tài)碼(如 200 表示成功,404 資源未找到)if response.status_code == 200: print("成功")
?**response.text**獲取響應(yīng)內(nèi)容(自動(dòng)解碼文本,如 HTML/XML)print(response.text[:500]) # 截取前500字符
?**response.json()**解析 JSON 響應(yīng)為 Python 字典或列表data = response.json(); print(data["temperature"])
?**response.headers**獲取響應(yīng)頭信息(如服務(wù)器類型、緩存策略)print(response.headers["Content-Type"])
?**response.raise_for_status()**自動(dòng)拋出異常(狀態(tài)碼非 200 時(shí)觸發(fā))try: response.raise_for_status() except requests.HTTPError: ...

4. 高級(jí)功能

  • ?文件上傳與下載

    # 上傳文件  
    files = {"file": open("report.pdf", "rb")}  
    requests.post("https://api.example.com/upload", files=files)[4,6](@ref)  
    
    # 流式下載大文件  
    with requests.get("https://example.com/large_video.mp4", stream=True) as r:  
        with open("video.mp4", "wb") as f:  
            for chunk in r.iter_content(chunk_size=8192):  
                f.write(chunk)  
  • ?超時(shí)與重試策略

    from requests.adapters import HTTPAdapter  
    from urllib3.util.retry import Retry  
    
    retry = Retry(total=3, backoff_factor=1, status_forcelist=[500, 502, 503])  
    adapter = HTTPAdapter(max_retries=retry)  
    session = requests.Session()  
    session.mount("https://", adapter)  
    session.get("https://unstable-api.com", timeout=5)  # 超時(shí)5秒,重試3次[4,6](@ref)  

四、應(yīng)用場(chǎng)景與實(shí)戰(zhàn)案例

  • ?數(shù)據(jù)采集與爬蟲

    • 抓取新聞標(biāo)題:requests.get() + BeautifulSoup 解析 HTML
    • 動(dòng)態(tài)內(nèi)容加載:配合 Selenium 處理 JavaScript 渲染頁(yè)面
  • ?API 集成開發(fā)

    • 調(diào)用天氣接口:requests.get("https://weather-api.com?city=北京")
    • 對(duì)接 ChatGPT:發(fā)送 JSON 請(qǐng)求并處理流式響應(yīng)
  • ?自動(dòng)化測(cè)試

    • 驗(yàn)證 REST API 功能:斷言響應(yīng)狀態(tài)碼和數(shù)據(jù)格式
    • 壓力測(cè)試:多線程并發(fā)發(fā)送請(qǐng)求(需結(jié)合 concurrent.futures
  • ?企業(yè)級(jí)應(yīng)用

    • 財(cái)務(wù)報(bào)表批量下載:會(huì)話保持 + 定時(shí)任務(wù)
    • 跨系統(tǒng)數(shù)據(jù)同步:OAuth 認(rèn)證 + POST/PUT 方法

?五、注意事項(xiàng)與優(yōu)化技巧

  • ?安全規(guī)范

    • 敏感數(shù)據(jù)(如 API Key)避免硬編碼,使用環(huán)境變量管理
    • 啟用 HTTPS 并驗(yàn)證證書:verify=True(默認(rèn))
  • ?性能調(diào)優(yōu)

    • 復(fù)用 Session 對(duì)象減少 TCP 握手開銷
    • 設(shè)置合理超時(shí):timeout=10 防止阻塞主線程
  • ?異常處理

    try:  
        response = requests.get(url, timeout=5)  
        response.raise_for_status()  
    except requests.Timeout:  
        print("請(qǐng)求超時(shí)")  
    except requests.ConnectionError:  
        print("網(wǎng)絡(luò)連接失敗")  

到此這篇關(guān)于Python中Requests庫(kù)的實(shí)現(xiàn)示例的文章就介紹到這了,更多相關(guān)Python Requests庫(kù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評(píng)論