溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

requests模塊使用

發(fā)布時間:2020-08-06 18:25:12 來源:ITPUB博客 閱讀:213 作者:Winter 欄目:編程語言

安裝 requests


# 在命令行工具中使用
pip install requests
# 使用前需要導(dǎo)入
import requests

下面我們來看一下requests庫的幾種常用高級用法

會話對象
  • 會話對象可以跨請求保持某些參數(shù),在同一個 Session 實(shí)例發(fā)出的所有請求之間保持 cookie,會話也可用來為請求方法提供缺省的數(shù)據(jù);

from requests import Session
s = Session()
# 會話拿到
r = s.get('http://www.baidu.com')
print(r)   # <Response [200]>
print(r.cookies)   #  <RequestsCookieJar[<Cookie BDORZ=27315 for .baidu.com/>]>
# 再次發(fā)起請求
r = s.get('https://www.csdn.net/')
print(r.text)

我們可以拿到一個名為 r 的 Response 對象,然后在這個對象中獲取所有我們想要的信息,大家可以自己執(zhí)行代碼看看輸出結(jié)果。

  • 會話還可以作為上下文管理器,這樣就能確保 with 區(qū)塊退出后即使發(fā)生了異常會話能被關(guān)閉;

import requests
with requests.get('http://httpbin.org/get', stream=True) as r:
    print(r.text)

  • 任何時候進(jìn)行了類似 requests.get() 的調(diào)用,都在做兩件主要的事情,一個是在構(gòu)建一個 Request 對象, 該對象將被發(fā)送到某個服務(wù)器請求或查詢一些資源,其二是一旦 requests 得到一個從服務(wù)器返回的響應(yīng)就會產(chǎn)生一個 Response 對象。該響應(yīng)對象包含服務(wù)器返回的所有信息,也包含你原來創(chuàng)建的 Request 對象;
使用Prepared Request對象
  • 當(dāng)你從 API 或者session會話調(diào)用中收到一個 Response 對象時,request 屬性其實(shí)是使用了 Prepared Request 對象。

from requests import Request, Session
s = Session()
# 獲取Prepared Request對象
req = Request('GET', url,
    data=data,
    headers=header
)
prepped = req.prepare()
# do something with prepped.body
# do something with prepped.headers
resp = s.send(prepped,
    stream=stream,
    verify=verify,
    proxies=proxies,
    cert=cert,
    timeout=timeout
)
print(resp.status_code)

SSL 證書驗(yàn)證
  • Requests 可以為 HTTPS 請求驗(yàn)證 SSL 證書,就像 web 瀏覽器一樣。verify 默認(rèn)參數(shù)就是true,開啟SSL 驗(yàn)證,如果將 verify 設(shè)置為 False,則會忽略對 SSL 證書的驗(yàn)證,但是會有警告,需要使用 urllib3.disable_warnings() ;

import requests
import urllib3
urllib3.disable_warnings()
# verify默認(rèn)參數(shù)就是true
ret = requests.get('https://github.com', verify=True)
print(ret.status_code)
# 也可以關(guān)閉verify, 但是會有警告
ret = requests.get('https://github.com', verify=False)
print(ret.status_code)

流式上傳
  • Requests支持流式上傳,允許發(fā)送大的數(shù)據(jù)流或文件而無需先把它們讀入內(nèi)存,要使用流式上傳,需要為請求體提供一個類文件對象;

with open('massive-body', 'rb') as f:
    requests.post('http://some.url/streamed', data=f)
與requests.post("http://httpbin.org/post", files=files)不一樣

塊編碼請求
  • 當(dāng)下載大文件時,用 Response.iter_content 或許更方便些。 requests.get(url) 默認(rèn)是下載在內(nèi)存中的,下載完成才存到硬盤上,可以用 Response.iter_content 來邊下載邊存

import requests
url = "http://DOMAIN/media/1.mp4"
# 這里設(shè)置stream=true的目的在于不會將內(nèi)容全部儲存在內(nèi)存中,而是根據(jù)chunk_size的大小,去下載內(nèi)容
ret = requests.get(url, stream=True)
with open('1.mp4', 'wb') as f:
    for block in ret.iter_content(chunk_size=1024):
        f.write(block)

POST 多個分塊編碼的文件
  • 使用POST表單提交的方式可以在一個請求中發(fā)送多個文件,只需要把文件設(shè)到一個元組的列表中。
    例如,假設(shè)你要上傳多個圖像文件到一個 HTML 表單,使用一個多文件 field 叫做 “images”:

<input type="file" name="images" multiple="true" required="true"/>

然后把文件設(shè)到一個元組的列表中,其中元組結(jié)構(gòu)為 (form_field_name, file_info):


import requests
url = 'http://httpbin.org/post'
multiple_files = [
        #  images是input的name屬性
        ('images', ('foo.png', open('foo.png', 'rb'), 'image/png')),
        ('images', ('bar.png', open('bar.png', 'rb'), 'image/png'))]
r = requests.post(url, files=multiple_files)
print(r.text)

設(shè)置Proxy代理
  • 如果需要使用代理,可以通過為任意請求方法提供 proxies 參數(shù)來往請求中設(shè)置代理,還可以傳遞用戶名和密碼;

import requests
#普通代理
proxies = {
   "http": "http://23.10.1.10:80",
   "https": "https://23.10.1.11:80",
}
# 往請求中設(shè)置代理(proxies)
r = requests.get("https://www.baidu.com", proxies=proxies)
print(r.status_code)
# 帶有用戶名和密碼的代理, basic認(rèn)證
proxies = {
   "http": "http://user:password@227.1.0.1:9999/",
}
r = requests.get("https://www.baidu.com", proxies=proxies)
print(r.status_code)
# 設(shè)置socks代理
proxies = {
   'http': 'socks5://127.0.0.1:1080',
   'https': 'socks5://127.0.0.1:1080'
}
r = requests.get("https://www.facebook.com", proxies=proxies)
print(r.status_code)

參考: https://www.9xkd.com/user/plan-view.html?id=3940257785

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI