百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

程序运行到哪了?应用进度条,从此再也不犯愁

off999 2024-09-14 07:16 22 浏览 0 评论

全文共2276字,预计学习时长7分钟


进度条真的棒极了!

进度条直观地展示了一个进程需要多久完成。它使人们不必担心进度停滞,免除了估计代码进程的麻烦。用户可以实时看到程序进程!


如果以前从没用过进度条,甚至没想过用进度条,可能会想当然地认为进度条会将代码复杂化,使其难以维护。


事实并非如此。只需几行代码,就能在命令行脚本及PySimpleGUI用户界面添加进度条了。


1、Alive progress库


第一个要学的是alive progress库,顾名思义,alive progress库能够让进度条动起来。比起之前的进度条,alive progress多了一些动画效果。然而,就代码而言,alive progress还是相当简单的:


  1. from alive_progress import alive_bar
  2. import timemylist = [1,2,3,4,5,6,7,8]with alive_bar(len(mylist)) as bar:
  3. for i in mylist:
  4. bar()
  5. time.sleep(1)

进度条效果如下:



再次提醒,别忘了看看alive progress库有哪些特性哦。


2、Progress库


接下来要学的Python库是Progress。


用户只需设定期望迭代次数及进度条的类型,并设置进度条在每次完成迭代时更新。


  1. import time
  2. from progress.bar import IncrementalBarmylist = [1,2,3,4,5,6,7,8]bar =IncrementalBar('Countdown', max = len(mylist))for item in mylist:
  3. bar.next()
  4. time.sleep(1)bar.finish()


返回得到:



如果不喜欢进度条的形式,还有很多其他的选择:



别忘了查看Progressbar的官方文档。


3、PySimpleGUI:图形进度条


与前文类似,只需几行代码就可以为命令行脚本添加图形进度条。



要达到这样的效果,只需要下面的代码:


  1. import PySimpleGUI as sg
  2. import timemylist = [1,2,3,4,5,6,7,8]for i, item in enumerate(mylist):
  3. sg.one_line_progress_meter('This ismy progress meter!', i+1, len(mylist), '-key-')
  4. time.sleep(1)

4、Tqdm库


最后,我们来学习tqdm库。


Tqdm是一种快捷的可扩展进度条,适用于Python和命令行界面(CLI)


就像上文提到的Python库一样,只须几行代码就能添加tqdm进度条。只是在设置方面有少许不同:


  1. import time
  2. from tqdm import tqdmmylist = [1,2,3,4,5,6,7,8]for i in tqdm(mylist):
  3. time.sleep(1)

从而得到:



与Progressbar一样,tqdm进度条也有几种不同选择。请务必查看相关官方说明。


PySimpleGUI应用中的进度条


继续学习如何在UI界面加入进度条。


UI界面:


代码如下:


  1. import PySimpleGUI as sg
  2. import timemylist = [1,2,3,4,5,6,7,8]progressbar = [
  3. [sg.ProgressBar(len(mylist),orientation='h', size=(51, 10), key='progressbar')]
  4. ]
  5. outputwin = [
  6. [sg.Output(size=(78,20))]
  7. ]layout = [
  8. [sg.Frame('Progress',layout=progressbar)],
  9. [sg.Frame('Output', layout =outputwin)],
  10. [sg.Submit('Start'),sg.Cancel()]
  11. ]window = sg.Window('Custom Progress Meter', layout)
  12. progress_bar = window['progressbar']while True:
  13. event, values =window.read(timeout=10)
  14. if event == 'Cancel' or event is None:
  15. break
  16. elif event == 'Start':
  17. for i,item in enumerate(mylist):
  18. print(item)
  19. time.sleep(1)
  20. progress_bar.UpdateBar(i +1)window.close()



没错,就是这么简单!


只需几行代码,就可以将进度条应用于Python脚本!这一点也不难,以后再也不用瞎猜程序运行到了哪一步!直接看自己设置的进度条,就能一目了然啦。


最后祝大家学习愉快~

留言点赞关注

我们一起分享AI学习与发展的干货

如转载,请后台留言,遵守转载规范

相关推荐

python入门到脱坑经典案例—清空列表

在Python中,清空列表是一个基础但重要的操作。clear()方法是最直接的方式,但还有其他方法也可以实现相同效果。以下是详细说明:1.使用clear()方法(Python3.3+推荐)...

python中元组,列表,字典,集合删除项目方式的归纳

九三,君子终日乾乾,夕惕若,厉无咎。在使用python过程中会经常遇到这四种集合数据类型,今天就对这四种集合数据类型中删除项目的操作做个总结性的归纳。列表(List)是一种有序和可更改的集合。允许重复...

Linux 下海量文件删除方法效率对比,最慢的竟然是 rm

Linux下海量文件删除方法效率对比,本次参赛选手一共6位,分别是:rm、find、findwithdelete、rsync、Python、Perl.首先建立50万个文件$testfor...

数据结构与算法——链式存储(链表)的插入及删除,

持续分享嵌入式技术,操作系统,算法,c语言/python等,欢迎小友关注支持上篇文章我们讲述了链表的基本概念及一些查找遍历的方法,本篇我们主要将一下链表的插入删除操作,以及采用堆栈方式如何创建链表。链...

Python自动化:openpyxl写入数据,插入删除行列等基础操作

importopenpyxlwb=openpyxl.load_workbook("example1.xlsx")sh=wb['Sheet1']写入数据#...

在Linux下软件的安装与卸载(linux里的程序的安装与卸载命令)

通过apt安装/协助软件apt是AdvancedPackagingTool,是Linux下的一款安装包管理工具可以在终端中方便的安装/卸载/更新软件包命令使用格式:安装软件:sudoapt...

Python 批量卸载关联包 pip-autoremove

pip工具在安装扩展包的时候会自动安装依赖的关联包,但是卸载时只删除单个包,无法卸载关联的包。pip-autoremove就是为了解决卸载关联包的问题。安装方法通过下面的命令安装:pipinsta...

用Python在Word文档中插入和删除文本框

在当今自动化办公需求日益增长的背景下,通过编程手段动态管理Word文档中的文本框元素已成为提升工作效率的关键技术路径。文本框作为文档排版中灵活的内容容器,既能承载多模态信息(如文字、图像),又可实现独...

Python 从列表中删除值的多种实用方法详解

#Python从列表中删除值的多种实用方法详解在Python编程中,列表(List)是一种常用的数据结构,具有动态可变的特性。当我们需要从列表中删除元素时,根据不同的场景(如按值删除、按索引删除、...

Python 中的前缀删除操作全指南(python删除前导0)

1.字符串前缀删除1.1使用内置方法Python提供了几种内置方法来处理字符串前缀的删除:#1.使用removeprefix()方法(Python3.9+)text="...

每天学点Python知识:如何删除空白

在Python中,删除空白可以分为几种不同的情况,常见的是针对字符串或列表中空白字符的处理。一、删除字符串中的空白1.删除字符串两端的空白(空格、\t、\n等)使用.strip()方法:s...

Linux系统自带Python2&yum的卸载及重装

写在前面事情的起因是我昨天在测试Linux安装Python3的shell脚本时,需要卸载Python3重新安装一遍。但是通过如下命令卸载python3时,少写了个3,不小心将系统自带的python2也...

如何使用Python将多个excel文件数据快速汇总?

在数据分析和处理的过程中,Excel文件是我们经常会遇到的数据格式之一。本文将通过一个具体的示例,展示如何使用Python和Pandas库来读取、合并和处理多个Excel文件的数据,并最终生成一个包含...

【第三弹】用Python实现Excel的vlookup功能

今天继续用pandas实现Excel的vlookup功能,假设我们的2个表长成这样:我们希望把Sheet2的部门匹在Sheet1的最后一列。话不多说,先上代码:importpandasaspd...

python中pandas读取excel单列及连续多列数据

案例:想获取test.xls中C列、H列以后(当H列后列数未知时)的所有数据。importpandasaspdfile_name=r'D:\test.xls'#表格绝对...

取消回复欢迎 发表评论: