如何在Python中恢复文件下载?

Sta*_*ked 14 python python-2.7 python-requests

我使用python 2.7请求模块使用以下代码下载二进制文件,如何使此代码"自动恢复"从部分下载的文件下载.

r = requests.get(self.fileurl, stream=True,  verify=False, allow_redirects=True)
if r.status_code == 200:
    CHUNK_SIZE = 8192
    bytes_read = 0
    with open(FileSave, 'wb') as f:
        itrcount=1
        for chunk in r.iter_content(CHUNK_SIZE):
            itrcount=itrcount+1
            f.write(chunk)
            bytes_read += len(chunk)
            total_per = 100 * float(bytes_read)/float(long(audioSize)+long(videoSize))


            self.progress_updates.emit('%d\n%s' % (total_per, 'Download Progress : ' + self.size_human(itrcount*CHUNK_SIZE) + '/' + Total_Size))
r.close()
Run Code Online (Sandbox Code Playgroud)

requests如果可能的话,我宁愿只使用模块来实现这一点.

Pio*_*ski 21

如果Web服务器支持范围请求,则可以将Range标头添加到您的请求中:

Range: bytes=StartPos-StopPos
Run Code Online (Sandbox Code Playgroud)

您将收到StartPos和StopPos之间的部分.如果不知道StopPos只是使用:

Range: bytes=StartPos-
Run Code Online (Sandbox Code Playgroud)

所以你的代码是:

def resume_download(fileurl, resume_byte_pos):
    resume_header = {'Range': 'bytes=%d-' % resume_byte_pos}
    return requests.get(fileurl, headers=resume_header, stream=True,  verify=False, allow_redirects=True)
Run Code Online (Sandbox Code Playgroud)

  • 您还需要将文件模式从"wb"更改为"ab"(要追加,否则您将覆盖已保存的部分). (6认同)
  • @Klik肯定不是当前文件大小减1 - 如果你下载0字节然后你不想从-1开始:)索引从0开始,所以你应该发送当前文件大小作为起始字节. (3认同)
  • 例如,您使用 Range 标头请求字节 0-2000000。然后,您使用``from pathlib import Path; 检查文件大小;路径 = 路径(..); print(path.stat().st_size`` 并返回 2000001 Bytes。您可以将此数字用于 Range 标头以请求从 2000001-... 的下一部分。 (2认同)