如何实现文件下载进度条呢?

比如有时候我们在利用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, "*"))

2、运行展示#

作者:YangRoc

出处:https://www.cnblogs.com/YangRoc/p/17186498.html

版权:本作品采用「署名-非商业性使用-相同方式共享 4.0 国际」许可协议进行许可。

posted @   Roc-xb  阅读(20)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 全程不用写代码,我用AI程序员写了一个飞机大战
· DeepSeek 开源周回顾「GitHub 热点速览」
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了

易微帮源码


易微帮官网

more_horiz
keyboard_arrow_up dark_mode palette
选择主题
menu
点击右上角即可分享
微信分享提示