zoukankan      html  css  js  c++  java
  • 大文件断点下载

    import sys, requests, os
    
    # 屏蔽warning信息
    requests.packages.urllib3.disable_warnings()
    
    def download(url, file_path):
        # 第一次请求是为了得到文件总大小
        r1 = requests.get(url, stream=True, verify=False)
        total_size = int(r1.headers['Content-Length'])
    
        # 这重要了,先看看本地文件下载了多少
        if os.path.exists(file_path):
            temp_size = os.path.getsize(file_path)  # 本地已经下载的文件大小
        else:
            temp_size = 0
        # 显示一下下载了多少
        print('本地已下载:', temp_size)
        print('文件总大小:', total_size)
        # 核心部分,这个是请求下载时,从本地文件已经下载过的后面下载
        headers = {'Range': 'bytes=%d-' % temp_size}
        # 重新请求网址,加入新的请求头的
        r = requests.get(url, stream=True, verify=False, headers=headers)
    
        # 下面写入文件也要注意,看到"ab"了吗?
        # "ab"表示追加形式写入文件
        with open(file_path, "ab") as f:
            for chunk in r.iter_content(chunk_size=1024):
                if chunk:
                    temp_size += len(chunk)
                    f.write(chunk)
                    f.flush()
    
                    ###这是下载实现进度显示####
                    done = int(50 * temp_size / total_size)
                    sys.stdout.write("
    [%s%s] %d%%" % ('█' * done, ' ' * (50 - done), 100 * temp_size / total_size))
                    sys.stdout.flush()
        print()  # 避免上面
     回车符
    
    
    if __name__ == '__main__':
        # link = r'https://nshlite.gph.netease.com/patch_20-08-26-18-30_20-09-02-12-00.lowp'
        # name = link.rsplit('/',1)[-1]
        link = r'xxx'
        name = 'xxx.xxx'
        path = fr'./{name}'
        # 调用一下函数试试
        download(link, path)
    
  • 相关阅读:
    Hadoop Gateway 部署
    java 命令--备忘
    整理下常用硬件性能参数
    python 脚本备份 mysql 数据库到 OSS
    pip 更换国内源
    记录闭包和立即执行函数
    Django 中文乱码问题&富文本显示
    mysql exceeded the 'max_questions' resource 记录
    sql server 数据字典的妙用
    Sublime Text指南
  • 原文地址:https://www.cnblogs.com/dadazunzhe/p/13611984.html
Copyright © 2011-2022 走看看