python?如何使用requests下載文件
使用requests下載文件
1、獲取token,或者session
如不需要可忽略
login_url = "http://xxxx/api/auth/login" login_data = {"username":"test3","password":"123456"} login_res = requests.post(url=login_url,data = login_data) token = login_res.json()["data"]["token"]
2、獲取下載路徑
如果請(qǐng)求后直接返回文件內(nèi)容,可直接進(jìn)行第三步
batch_url = "http://xxxx/api/models/batch" batch_data = {"ids":"[4]","version_number":"[309]"} headers = {"Authorization":"bearer %s" % token} batch_res = requests.get(url=batch_url,params=batch_data,headers=headers)
3、根據(jù)下載路徑拼接下載url
完成文件下載以及寫入
file_path = batch_res.json()['data']['file_path'] file_name = batch_res.json()['data']['file_name'] down_url = "http://xxxx/api/report/down" down_data = {"type":2, ? ? ? ? ? ? ?"file_path":file_path, ? ? ? ? ? ? ?"file_name":file_name, ? ? ? ? ? ? ?"token":token ? ? ? ? ? ? ?} down_res = requests.get(url=down_url,params=down_data) with open(file_name,"wb") as code: ? ? code.write(down_res.content)
備注:
第二步返回json數(shù)據(jù),包含路徑、文件名,實(shí)際是文件生成過(guò)程,第三步下載在服務(wù)端生成的文件,有時(shí)第三步無(wú)法在頁(yè)面F12查看到,需要使用抓包工具獲取
用requests.get下載文件
不知道大家有沒(méi)有遇到這樣的問(wèn)題
就是url源不穩(wěn)定,時(shí)不時(shí)下載到空文件,我終于想到了一個(gè)解決的好辦法,分享給大家。
def downloadfile(url,filename=None): if(not filename): #如果參數(shù)沒(méi)有指定文件名 filename=os.path.basename(url) #取用url的尾巴為文件名 leng=1 while(leng==1): torrent=requests.get(url,headers=headers) leng=len(list(torrent.iter_content(1024))) #下載區(qū)塊數(shù) if(leng==1): #如果是1 就是空文件 重新下載 print(filename,'下載失敗,重新下載') sleep(1) else: print(path,'下載完成') with open(filename,'wb') as f: for chunk in torrent.iter_content(1024): #防止文件過(guò)大,以1024為單位一段段寫入 f.write(chunk)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
- python中requests模塊的使用方法
- python中requests庫(kù)session對(duì)象的妙用詳解
- python采用requests庫(kù)模擬登錄和抓取數(shù)據(jù)的簡(jiǎn)單示例
- Python使用requests發(fā)送POST請(qǐng)求實(shí)例代碼
- python中requests使用代理proxies方法介紹
- Python爬蟲(chóng)庫(kù)requests獲取響應(yīng)內(nèi)容、響應(yīng)狀態(tài)碼、響應(yīng)頭
- Python3使用requests包抓取并保存網(wǎng)頁(yè)源碼的方法
- 詳解Python requests 超時(shí)和重試的方法
- Python requests timeout的設(shè)置
- 解決Python requests 報(bào)錯(cuò)方法集錦
- Python中Requests庫(kù)的實(shí)現(xiàn)示例
相關(guān)文章
python實(shí)現(xiàn)一個(gè)點(diǎn)繞另一個(gè)點(diǎn)旋轉(zhuǎn)后的坐標(biāo)
今天小編就為大家分享一篇python實(shí)現(xiàn)一個(gè)點(diǎn)繞另一個(gè)點(diǎn)旋轉(zhuǎn)后的坐標(biāo),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-12-12Pandas中常用的七個(gè)時(shí)間戳處理函數(shù)使用總結(jié)
在零售、經(jīng)濟(jì)和金融等行業(yè),數(shù)據(jù)總是由于貨幣和銷售而不斷變化,生成的所有數(shù)據(jù)都高度依賴于時(shí)間。如果這些數(shù)據(jù)沒(méi)有時(shí)間戳或標(biāo)記,實(shí)際上很難管理所有收集的數(shù)據(jù)。本文為大家準(zhǔn)備了Pandas中常用的七個(gè)時(shí)間戳處理函數(shù),需要的可以參考一下2022-04-04Pandas的Series結(jié)構(gòu)及常用操作實(shí)例
這篇文章主要介紹了Pandas的Series結(jié)構(gòu)及常用操作實(shí)例,Series序列,是一種一維的結(jié)構(gòu),類似于一維列表和ndarray中的一維數(shù)組,但是功能比他們要更為強(qiáng)大,Series由兩部分組成:索引index和數(shù)值values,需要的朋友可以參考下2023-07-07python使用正則表達(dá)式匹配反斜杠\遇到的問(wèn)題
在學(xué)習(xí)Python正則式的過(guò)程中,有一個(gè)問(wèn)題一直困擾我,如何去匹配一個(gè)反斜杠(即“\”),下面這篇文章主要給大家介紹了關(guān)于python使用正則表達(dá)式匹配反斜杠\的相關(guān)資料,需要的朋友可以參考下2022-09-09Python 使用 prettytable 庫(kù)打印表格美化輸出功能
這篇文章主要介紹了Python 使用 prettytable 庫(kù)打印表格美化輸出功能,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-12-12