这篇文章主要介绍了python中怎么使用requests下载文件的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇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、获取下载路径

如果请求后直接返回文件内容,可直接进行第三步

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、根据下载路径拼接下载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)withopen(file_name,"wb")ascode:code.write(down_res.content)

备注:

第二步返回json数据,包含路径、文件名,实际是文件生成过程,第三步下载在服务端生成的文件,有时第三步无法在页面F12查看到,需要使用抓包工具获取

用requests.get下载文件不知道大家有没有遇到这样的问题

就是url源不稳定,时不时下载到空文件,我终于想到了一个解决的好办法,分享给大家。

defdownloadfile(url,filename=None):if(notfilename):#如果参数没有指定文件名filename=os.path.basename(url)#取用url的尾巴为文件名leng=1while(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,'下载完成')withopen(filename,'wb')asf:forchunkintorrent.iter_content(1024):#防止文件过大,以1024为单位一段段写入f.write(chunk)

关于“python中怎么使用requests下载文件”这篇文章的内容就介绍到这里,感谢各位的阅读!相信大家对“python中怎么使用requests下载文件”知识都有一定的了解,大家如果还想学习更多知识,欢迎关注亿速云行业资讯频道。