requests 实现爬虫下载进度实时查看

本文介绍了一种使用Python的Requests库实现文件下载时显示实时进度的方法。通过设置stream参数为True,配合iter_content逐块读取响应内容,计算已下载百分比并在控制台输出,实现了大文件下载时的内存优化及进度监控。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

requests 实现爬虫下载进度实时查看

import requests
def Donwler(file_url,file_path):
    headers = {
        "User-Agent": "Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/63.0.3239.132 Safari/537.36"}

    # stream参数默认情况下是False会立即取下载并放到内存当中
    # 如果文件比较大会出现内存不足的情况  True并不会立马取下载而是在使用
    # iter_content:一块一块的遍历要下载的内容
    # iter_lines:一行一行的遍历要下载的内容  这两个参数的时候取遍历下载
    response = requests.get(url=file_url,headers=headers,stream=True)

    chunk_size = 1024 # 每次最大请求字节
    content_size = int(response.headers['content-length']) # 获得本次请求的字节
    data_count = 0

    with open(file_path, "wb") as file:

        for data in response.iter_content(chunk_size=chunk_size): # 一块一块以下载
            file.write(data)
            data_count = data_count + len(data)
            now = (data_count / content_size) * 100 # 计算下载的进度
            print("\r 文件下载进度:%d%%(%d/%d) - %s" % (now, data_count, content_size, file_path), end=" ")
if __name__ == '__main__':
    headers = {
        "User-Agent": "Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/63.0.3239.132 Safari/537.36",
    }
    file_url = 'https://down.360safe.com/se/360se8.1.1.404.exe'  # 文件链接
    file_path = "C:\\demo/002.exe"  # 文件路径
    Down_load(file_url, file_path)
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值