如何用Python实现下载文件时显示进度条及预估下载时间?

2026-05-26 23:481阅读0评论SEO教程
  • 内容介绍
  • 相关推荐

本文共计1126个文字,预计阅读时间需要5分钟。

如何用Python实现下载文件时显示进度条及预估下载时间?

在下载文件时,可以方便地显示下载进度和时间。实现这一功能的方法非常简单。以下是一个进度条模块的示例,它还包括运行时间,也就是下载时间。

pythonimport osimport time

def download_file(url, file_name): # 使用 os.popen() 打开文件,并使用 'wb' 模式写入二进制数据 with open(file_name, 'wb') as f: os.popen('wget', args=(url, '-O', file_name, '--show-progress'))

start_time=time.time()

while True: # 检查文件是否下载完成 if os.path.getsize(file_name)==os.path.getsize(file_name + '.orig'): break

# 计算已下载的字节数和总字节数 size=os.path.getsize(file_name) total_size=os.path.getsize(file_name + '.orig') progress=(size / total_size) * 100

# 计算已下载的时间 elapsed_time=time.time() - start_time

print(fDownloaded {progress:.2f}% in {elapsed_time:.2f}s)

print(Download completed.)

示例使用download_file('http://example.com/file.zip', 'downloaded_file.zip')

如何用Python实现下载文件时显示进度条及预估下载时间?

此模块使用了 `os` 库来处理文件,并调用了 `wget` 命令来下载文件。同时,它还记录了下载时间,并在下载过程中不断更新进度条。

大家在下载文件时能够显示下载进度和时间非常好,其实实现它方法很简单,这里我写了个进度条的模块,其中还附带上了运行时间也就是下载时间了。

该模块调用了三个库:

1.os 2.requests 3.time

话不多说,先上代码!!!.

# 进度条模块 def progressbar(url,path): if not os.path.exists(path): # 看是否有该文件夹,没有则创建文件夹 os.mkdir(path) start = time.time() #下载开始时间 response = requests.get(url, stream=True) #stream=True必须写上 size = 0 #初始化已下载大小 chunk_size = 1024 # 每次下载的数据大小 content_size = int(response.headers['content-length']) # 下载文件总大小 try: if response.status_code == 200: #判断是否响应成功 print('Start download,[File size]:{size:.2f} MB'.format(size = content_size / chunk_size /1024)) #开始下载,显示下载文件大小 filepath = path+'\name.extension name' #设置图片name,注:必须加上扩展名 with open(filepath,'wb') as file: #显示进度条 for data in response.iter_content(chunk_size = chunk_size): file.write(data) size +=len(data) print('\r'+'[下载进度]:%s%.2f%%' % ('>'*int(size*50/ content_size), float(size / content_size * 100)) ,end=' ') end = time.time() #下载结束时间 print('Download completed!,times: %.2f秒' % (end - start)) #输出下载用时时间 except:

实现原理其实很简单,我们一般下载东西使用的requests.get(url).content的方法下载来的文件是二进制文件,我们只要通过for循环每次下载1024kb,到最后获取文件的总大小,即可完成我们的功能实现了!.

通过上面这个函数我们就实现了简单的进度条以及所需时间的功能,我们用了两个参数,我们下载个皮卡丘图片来试试效果:

效果还不错~~注:[下载进度]后面的‘>'是有动态显示的,这里可能看不到,可以在自己的环境下测试看看!!

实例代码:

import os import requests import time # 进度条模块 def progressbar(url,path): if not os.path.exists(path): # 看是否有该文件夹,没有则创建文件夹 os.mkdir(path) start = time.time() #下载开始时间 response = requests.get(url, stream=True) size = 0 #初始化已下载大小 chunk_size = 1024 # 每次下载的数据大小 content_size = int(response.headers['content-length']) # 下载文件总大小 try: if response.status_code == 200: #判断是否响应成功 print('Start download,[File size]:{size:.2f} MB'.format(size = content_size / chunk_size /1024)) #开始下载,显示下载文件大小 filepath = path+'\Pikachu.jpg' #设置图片name,注:必须加上扩展名 with open(filepath,'wb') as file: #显示进度条 for data in response.iter_content(chunk_size = chunk_size): file.write(data) size +=len(data) print('\r'+'[下载进度]:%s%.2f%%' % ('>'*int(size*50/ content_size), float(size / content_size * 100)) ,end=' ') end = time.time() #下载结束时间 print('Download completed!,times: %.2f秒' % (end - start)) #输出下载用时时间 except: print('Error!') def main(): #下载皮卡丘图片 url = 'img.moegirl.org/common/thumb/e/ed/%E7%9A%AE%E5%8D%A1%E4%B8%98%E4%B9%8B%E6%AD%8C.jpg/1200px-%E7%9A%AE%E5%8D%A1%E4%B8%98%E4%B9%8B%E6%AD%8C.jpg' path = r'E:\123' # 设置下载到本地的地址 progressbar(url,path) if __name__ == '__main__': main()

总结

到此这篇关于Python 给下载文件显示进度条和下载时间的文章就介绍到这了,更多相关python下载文件进度条下载时间内容请搜索易盾网络以前的文章或继续浏览下面的相关文章希望大家以后多多支持易盾网络!

本文共计1126个文字,预计阅读时间需要5分钟。

如何用Python实现下载文件时显示进度条及预估下载时间?

在下载文件时,可以方便地显示下载进度和时间。实现这一功能的方法非常简单。以下是一个进度条模块的示例,它还包括运行时间,也就是下载时间。

pythonimport osimport time

def download_file(url, file_name): # 使用 os.popen() 打开文件,并使用 'wb' 模式写入二进制数据 with open(file_name, 'wb') as f: os.popen('wget', args=(url, '-O', file_name, '--show-progress'))

start_time=time.time()

while True: # 检查文件是否下载完成 if os.path.getsize(file_name)==os.path.getsize(file_name + '.orig'): break

# 计算已下载的字节数和总字节数 size=os.path.getsize(file_name) total_size=os.path.getsize(file_name + '.orig') progress=(size / total_size) * 100

# 计算已下载的时间 elapsed_time=time.time() - start_time

print(fDownloaded {progress:.2f}% in {elapsed_time:.2f}s)

print(Download completed.)

示例使用download_file('http://example.com/file.zip', 'downloaded_file.zip')

如何用Python实现下载文件时显示进度条及预估下载时间?

此模块使用了 `os` 库来处理文件,并调用了 `wget` 命令来下载文件。同时,它还记录了下载时间,并在下载过程中不断更新进度条。

大家在下载文件时能够显示下载进度和时间非常好,其实实现它方法很简单,这里我写了个进度条的模块,其中还附带上了运行时间也就是下载时间了。

该模块调用了三个库:

1.os 2.requests 3.time

话不多说,先上代码!!!.

# 进度条模块 def progressbar(url,path): if not os.path.exists(path): # 看是否有该文件夹,没有则创建文件夹 os.mkdir(path) start = time.time() #下载开始时间 response = requests.get(url, stream=True) #stream=True必须写上 size = 0 #初始化已下载大小 chunk_size = 1024 # 每次下载的数据大小 content_size = int(response.headers['content-length']) # 下载文件总大小 try: if response.status_code == 200: #判断是否响应成功 print('Start download,[File size]:{size:.2f} MB'.format(size = content_size / chunk_size /1024)) #开始下载,显示下载文件大小 filepath = path+'\name.extension name' #设置图片name,注:必须加上扩展名 with open(filepath,'wb') as file: #显示进度条 for data in response.iter_content(chunk_size = chunk_size): file.write(data) size +=len(data) print('\r'+'[下载进度]:%s%.2f%%' % ('>'*int(size*50/ content_size), float(size / content_size * 100)) ,end=' ') end = time.time() #下载结束时间 print('Download completed!,times: %.2f秒' % (end - start)) #输出下载用时时间 except:

实现原理其实很简单,我们一般下载东西使用的requests.get(url).content的方法下载来的文件是二进制文件,我们只要通过for循环每次下载1024kb,到最后获取文件的总大小,即可完成我们的功能实现了!.

通过上面这个函数我们就实现了简单的进度条以及所需时间的功能,我们用了两个参数,我们下载个皮卡丘图片来试试效果:

效果还不错~~注:[下载进度]后面的‘>'是有动态显示的,这里可能看不到,可以在自己的环境下测试看看!!

实例代码:

import os import requests import time # 进度条模块 def progressbar(url,path): if not os.path.exists(path): # 看是否有该文件夹,没有则创建文件夹 os.mkdir(path) start = time.time() #下载开始时间 response = requests.get(url, stream=True) size = 0 #初始化已下载大小 chunk_size = 1024 # 每次下载的数据大小 content_size = int(response.headers['content-length']) # 下载文件总大小 try: if response.status_code == 200: #判断是否响应成功 print('Start download,[File size]:{size:.2f} MB'.format(size = content_size / chunk_size /1024)) #开始下载,显示下载文件大小 filepath = path+'\Pikachu.jpg' #设置图片name,注:必须加上扩展名 with open(filepath,'wb') as file: #显示进度条 for data in response.iter_content(chunk_size = chunk_size): file.write(data) size +=len(data) print('\r'+'[下载进度]:%s%.2f%%' % ('>'*int(size*50/ content_size), float(size / content_size * 100)) ,end=' ') end = time.time() #下载结束时间 print('Download completed!,times: %.2f秒' % (end - start)) #输出下载用时时间 except: print('Error!') def main(): #下载皮卡丘图片 url = 'img.moegirl.org/common/thumb/e/ed/%E7%9A%AE%E5%8D%A1%E4%B8%98%E4%B9%8B%E6%AD%8C.jpg/1200px-%E7%9A%AE%E5%8D%A1%E4%B8%98%E4%B9%8B%E6%AD%8C.jpg' path = r'E:\123' # 设置下载到本地的地址 progressbar(url,path) if __name__ == '__main__': main()

总结

到此这篇关于Python 给下载文件显示进度条和下载时间的文章就介绍到这了,更多相关python下载文件进度条下载时间内容请搜索易盾网络以前的文章或继续浏览下面的相关文章希望大家以后多多支持易盾网络!