# 在命令行工具中使用
pip install requests
# 使用前需要導(dǎo)入
import requests
下面我們來(lái)看一下requests庫(kù)的幾種常用高級(jí)用法
創(chuàng)新互聯(lián)專(zhuān)注為客戶(hù)提供全方位的互聯(lián)網(wǎng)綜合服務(wù),包含不限于成都網(wǎng)站設(shè)計(jì)、成都網(wǎng)站建設(shè)、烈山網(wǎng)絡(luò)推廣、重慶小程序開(kāi)發(fā)公司、烈山網(wǎng)絡(luò)營(yíng)銷(xiāo)、烈山企業(yè)策劃、烈山品牌公關(guān)、搜索引擎seo、人物專(zhuān)訪(fǎng)、企業(yè)宣傳片、企業(yè)代運(yùn)營(yíng)等,從售前售中售后,我們都將竭誠(chéng)為您服務(wù),您的肯定,是我們最大的嘉獎(jiǎng);創(chuàng)新互聯(lián)為所有大學(xué)生創(chuàng)業(yè)者提供烈山建站搭建服務(wù),24小時(shí)服務(wù)熱線(xiàn):13518219792,官方網(wǎng)址:muchs.cn
from requests import Session
s = Session()
# 會(huì)話(huà)拿到
r = s.get('http://www.baidu.com')
print(r) # <Response [200]>
print(r.cookies) # <RequestsCookieJar[<Cookie BDORZ=27315 for .baidu.com/>]>
# 再次發(fā)起請(qǐng)求
r = s.get('https://www.csdn.net/')
print(r.text)
我們可以拿到一個(gè)名為
r
的 Response 對(duì)象,然后在這個(gè)對(duì)象中獲取所有我們想要的信息,大家可以自己執(zhí)行代碼看看輸出結(jié)果。
import requests
with requests.get('http://httpbin.org/get', stream=True) as r:
print(r.text)
requests.get()
的調(diào)用,都在做兩件主要的事情,一個(gè)是在構(gòu)建一個(gè) Request 對(duì)象, 該對(duì)象將被發(fā)送到某個(gè)服務(wù)器請(qǐng)求或查詢(xún)一些資源,其二是一旦 requests 得到一個(gè)從服務(wù)器返回的響應(yīng)就會(huì)產(chǎn)生一個(gè) Response 對(duì)象。該響應(yīng)對(duì)象包含服務(wù)器返回的所有信息,也包含你原來(lái)創(chuàng)建的 Request 對(duì)象;
Prepared Request
對(duì)象。
from requests import Request, Session
s = Session()
# 獲取Prepared Request對(duì)象
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)
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, 但是會(huì)有警告
ret = requests.get('https://github.com', verify=False)
print(ret.status_code)
with open('massive-body', 'rb') as f:
requests.post('http://some.url/streamed', data=f)
與requests.post("http://httpbin.org/post", files=files)不一樣
Response.iter_content
或許更方便些。
requests.get(url)
默認(rèn)是下載在內(nèi)存中的,下載完成才存到硬盤(pán)上,可以用
Response.iter_content
來(lái)邊下載邊存
import requests
url = "http://DOMAIN/media/1.mp4"
# 這里設(shè)置stream=true的目的在于不會(huì)將內(nèi)容全部?jī)?chǔ)存在內(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)
<input type="file" name="images" multiple="true" required="true"/>
然后把文件設(shè)到一個(gè)元組的列表中,其中元組結(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)
import requests
#普通代理
proxies = {
"http": "http://23.10.1.10:80",
"https": "https://23.10.1.11:80",
}
# 往請(qǐng)求中設(shè)置代理(proxies)
r = requests.get("https://www.baidu.com", proxies=proxies)
print(r.status_code)
# 帶有用戶(hù)名和密碼的代理, 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
當(dāng)前文章:requests模塊使用
網(wǎng)站鏈接:http://muchs.cn/article26/jpdccg.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供定制網(wǎng)站、企業(yè)建站、手機(jī)網(wǎng)站建設(shè)、微信小程序、網(wǎng)站建設(shè)、電子商務(wù)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話(huà):028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)