使用 python 获取下载文件的速度

Get the speed of downloading a file using python

我正在使用请求库下载文件,我得到了很多信息。关于回复,例如:尺寸、类型和日期。但我需要获取下载速度并为其设置最大值和最小值。我怎样才能获得下载速度?

代码如下:

import requests
import sys


link = "https://upload.wikimedia.org/wikipedia/commons/4/47/PNG_transparency_demonstration_1.png"
file_name = "downloaded.png"
response = requests.get(link, stream=True)
with open(file_name, "wb") as f:
        print "Downloading %s" % file_name
        response = requests.get(link, stream=True)
        total_length = int(response.headers.get('content-length'))
        print response.headers["content-type"]
        print total_length / 1024, "Kb"
        print int(response.headers["Age"]) * (10 ** -6), "Sec"
        print response.headers["date"]

        if total_length is None: # no content length header
            f.write(response.content)
        else:
            dl = 0
            for data in response.iter_content(chunk_size=4096):
                dl += len(data)
                f.write(data)
                done = int(50 * dl / total_length)
                sys.stdout.write("\r[%s%s]" % ('=' * done, ' ' * (50-done)) )
                sys.stdout.flush()

这是输出:

Downloading downloaded.png
image/png
213 Kb
0.054918 Sec
Wed, 19 Oct 2016 08:43:47 GMT
[==================================================]

我刚刚添加了 import timestart 变量,并将 sys.stdout.write 行替换为以下行:How to measure download speed and progress using requests?

import requests
import sys
import time


link = "https://upload.wikimedia.org/wikipedia/commons/4/47/PNG_transparency_demonstration_1.png"
file_name = "downloaded.png"
start = time.clock()
response = requests.get(link, stream=True)
with open(file_name, "wb") as f:
    print "Downloading %s" % file_name
    response = requests.get(link, stream=True)
    total_length = int(response.headers.get('content-length'))
    print response.headers["content-type"]
    print total_length / 1024, "Kb"
    print int(response.headers["Age"]) * (10 ** -6), "Sec"
    print response.headers["date"]

    if total_length is None: # no content length header
        f.write(response.content)
    else:
        dl = 0
        for data in response.iter_content(chunk_size=4096):
            dl += len(data)
            f.write(data)
            done = int(50 * dl / total_length)
            sys.stdout.write("\r[%s%s] %s bps" % ('=' * done, ' ' * (50-done), dl//(time.clock() - start)))
            sys.stdout.flush()