我在stackoverflow上看到了很多问题,但没有一个答案给出了一个简单优雅的方法。
link = "http://download.thinkbroadband.com/10MB.zip"
file_name = "test"
with open(file_name, "wb") as f:
print('Downloading: {}'.format(file_name))
response = requests.get(link, stream=True)
total_length = response.headers.get('content-length')
if total_length is None:
f.write(response.content)
else:
dl = 0
total_length = int(total_length)
for data in response.iter_content(chunk_size=4096):
dl += len(data)
f.write(data)
done = int(50 * dl / total_length)
sys.stdout.write("\r[%s%s]" % ('=' * done, ' ' * (50-done)))
sys.stdout.flush()
下载文件后,我可以获得更多详细信息吗?以前的所有问题都没有一个简单的答案。
答案 0 :(得分:1)
为什么重新发明轮子?使用tqdm。按照链接并按照说明导入tqdm并为任何迭代添加进度条。例如:
from tqdm import tqdm
...
for data in tqdm(response.iter_content(chunk_size=4096)):
# additional logic here
...
阅读提供的pypi链接中的示例,以向进度条添加其他信息。