您好,登錄后才能下訂單哦!
這篇文章主要介紹了python中怎么使用requests下載文件的相關知識,內容詳細易懂,操作簡單快捷,具有一定借鑒價值,相信大家閱讀完這篇python中怎么使用requests下載文件文章都會有所收獲,下面我們一起來看看吧。
如不需要可忽略
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"]
如果請求后直接返回文件內容,可直接進行第三步
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)
完成文件下載以及寫入
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數據,包含路徑、文件名,實際是文件生成過程,第三步下載在服務端生成的文件,有時第三步無法在頁面F12查看到,需要使用抓包工具獲取
就是url源不穩定,時不時下載到空文件,我終于想到了一個解決的好辦法,分享給大家。
def downloadfile(url,filename=None): if(not filename): #如果參數沒有指定文件名 filename=os.path.basename(url) #取用url的尾巴為文件名 leng=1 while(leng==1): torrent=requests.get(url,headers=headers) leng=len(list(torrent.iter_content(1024))) #下載區塊數 if(leng==1): #如果是1 就是空文件 重新下載 print(filename,'下載失敗,重新下載') sleep(1) else: print(path,'下載完成') with open(filename,'wb') as f: for chunk in torrent.iter_content(1024): #防止文件過大,以1024為單位一段段寫入 f.write(chunk)
關于“python中怎么使用requests下載文件”這篇文章的內容就介紹到這里,感謝各位的閱讀!相信大家對“python中怎么使用requests下載文件”知識都有一定的了解,大家如果還想學習更多知識,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。