比如有时候我们在利用python下载文件的时候,通常情况下,文件下载过程我们是感知不到的,只有等文件下载完成,我们才能知道,该文件已经下载完成,假如此时下载文件很大,下载
比如有时候我们在利用python下载文件的时候,通常情况下,文件下载过程我们是感知不到的,只有等文件下载完成,我们才能知道,该文件已经下载完成,假如此时下载文件很大,下载时间就会比较漫长,如果这时候有一个下载进度条,那就太好了,在此封装一个文件下载进度条工具方法,拿来即用。
目录
1、程序源码
2、运行展示
1、程序源码
#!/usr/bin/python# -*- coding: UTF-8 -*-
"""
@author: Roc-xb
"""
import requests
import time
def save_file(url, filename):
start = time.time() # 开始时间
size = 0
headers = {
"user-agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/92.0.4515.159 Safari/537.36"
} # 请求头参数
res = requests.get(url, headers=headers, stream=True)
chunk_size = 1024 # 每次下载数据大小
content_size = int(res.headers["content-length"]) # 文件总字节数
if res.status_code == 200:
print("[文件地址]:", url)
print('[文件名称]:', filename)
print('[文件大小]: {:.3f} MB'.format(content_size / chunk_size / 1024))
with open(f"{filename}", 'wb') as f:
for data in res.iter_content(chunk_size=chunk_size):
f.write(data)
size += len(data) # 已下载文件大小
print('\r[下载进度]: {}{:.2f}%'.format('>' * int(size * 50 / content_size), float(size / content_size * 100)),end='') # 下载进度条
end = time.time() # 结束时间
print("\n[下载时间]: {:.2f}s".format(end - start))
print("".center(100, "*"))