我正在使用requests
下载文件,但是对于大文件,我每次都需要检查磁盘上文件的大小,因为我无法以百分比显示进度,并且我还想知道下载速度。我该怎么做呢?这是我的代码:
import requests
import sys
import time
import os
def downloadFile(url, directory) :
localFilename = url.split('/')[-1]
r = requests.get(url, stream=True)
start = time.clock()
f = open(directory + '/' + localFilename, 'wb')
for chunk in r.iter_content(chunk_size = 512 * 1024) :
if chunk :
f.write(chunk)
f.flush()
os.fsync(f.fileno())
f.close()
return (time.clock() - start)
def main() :
if len(sys.argv) > 1 :
url = sys.argv[1]
else :
url = raw_input("Enter the URL : ")
directory = raw_input("Where would you want to save the file ?")
time_elapsed = downloadFile(url, directory)
print "Download complete..."
print "Time Elapsed: " + time_elapsed
if __name__ == "__main__" :
main()
我认为一种方法是每次在for
循环中读取文件并根据 header 计算进度百分比Content-Length
。但这对于大文件(大约 500MB)来说又是一个问题。还有其他方法吗?