断点继续下载模块

import sys
import requests
import os
import time

# 屏蔽warning信息
requests.packages.urllib3.disable_warnings()
headers = {
	"User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/79.0.3945.130 Safari/537.36"}


def download(url, file_path):
	# 第一次请求是为了得到文件总大小
	r1 = requests.get(url=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:', temp_size)
	print('total_size:', total_size)
	# 核心部分,这个是请求下载时,从本地文件已经下载过的后面下载
	headers = {'Range': 'bytes=%d-' % temp_size}
	# 重新请求网址,加入新的请求头的
	r = requests.get(url=url, headers=headers, stream=True, verify=False)

	# 下面写入文件也要注意,看到"ab"了吗?
	# "ab"表示追加形式写入文件
	with open(file_path, "ab+") as f:
		for chunk in r.iter_content(chunk_size=102400):
			if chunk:
				temp_size += len(chunk)
				f.write(chunk)
				f.flush()

				###这是下载实现进度显示####
				done = int(50 * temp_size / total_size)
				sys.stdout.write("\r[%s%s] %d%%" % ('█' * done, ' ' * (50 - done), 100 * temp_size / total_size))
				sys.stdout.flush()
	print()  # 避免上面\r 回车符





  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值