进度条Progress的用法介绍

简介: 进度条Progress的用法介绍

当程序需要执行大量的任务且执行时间比较长时,此时用户希望实时了解当前任务执行进度情况,尤其是希望能够通过可视化的形式进行展示,进度条Progress为此而生。

基本用法

在具体使用之前需要安装progress依赖。

pip install progress

进度条Progress的用法非常简单,首先导入库Bar,其次设置名字、数据长度、进度条填充字符进行初始化,接下来就是进入具体任务的执行,bar.suffix设置进度条后缀信息,bar.next进入下一次迭代,全部结束后bar.finish。后缀信息的设置使用了格式化字符串相关知识,示例提供的格式化形式值得借鉴和参考。

代码清单 2.8 进度条Progress示例
import time
from progress.bar import Bar
mylist = range(8)
bar = Bar('Processing', max=len(mylist), fill='#')
size = len(mylist)
for i, item in enumerate(mylist):
    time.sleep(1)
    bar.suffix = '({i}/{size}) | ETA: {eta:} '.format(eta=bar.eta_td, item=item, i=i, size=size)
    bar.next()
bar.finish()

在设置bar后缀时,也可以使用f-string的方式,这样更加便捷,如下所示:

bar.suffix = f'({idx + 1}/{size}) | ETA: {bar.eta_td:}'

关键技术点

(1) Pycharm中并未显示进度条而终端Terminal中运行,正常显示。

可以通过在Pycharm中模拟终端行为来解决该问题,具体做法是首先打开当前运行配置页面如图2. 1 第1步。


8a158c9687b84f3382e63ceb6adcca51.png

其次,勾选”Emulate terminal in output console”选项,如图2. 2 第2步。

(2) 进度条格式化信息输出。

通过bar.suffix添加具体的后缀信息,可以添加多个关键字段的信息,并以’|’竖线分割,第一个字段可以设置为当前完成任务数与总体任务数,这样可以更加清晰的了解任务进度情况。


eta和eta_td的区别,两者都表示剩余时间,后者以字符串增量的形式展示更符合人类认知。elapsed和elapsed_td的区别与此类似。


目录
相关文章
|
前端开发 JavaScript
设置控件不能点击(pointer-events)
设置控件不能点击(pointer-events)
59 0
|
3月前
Vue3进度条(Progress)
这是一个基于 Vue2 的进度条组件,支持线性 (`line`) 和圆形 (`circle`) 两种模式。可通过多种属性自定义进度条的样式和行为,包括宽度、进度百分比、颜色、线宽、线帽样式等。此外,还支持显示进度文本或图标,并允许通过插槽自定义内容。该组件提供了丰富的配置选项,适用于多种应用场景。
369 5
Vue3进度条(Progress)
|
3月前
|
JavaScript
Vue2进度条(Progress)
这篇文章介绍了如何在Vue 3框架中创建一个可自定义设置的进度条组件,包括进度条的宽度、当前进度、线条宽度和是否显示进度信息等属性。
111 2
Vue2进度条(Progress)
|
3月前
【Qt 学习笔记】Qt常用控件 | 显示类控件 | Progress Bar的使用及说明
【Qt 学习笔记】Qt常用控件 | 显示类控件 | Progress Bar的使用及说明
445 0
|
4月前
【亲测有效】Element UI 自定义 Notification 通知样式不生效,设置this.$notify样式不生效问题
【亲测有效】Element UI 自定义 Notification 通知样式不生效,设置this.$notify样式不生效问题
159 0
|
Web App开发 前端开发 容器
|
移动开发 前端开发 JavaScript
网页|利用progress实现进度条效果
网页|利用progress实现进度条效果
514 0
|
JavaScript 前端开发 测试技术
UI 提供的【progress-step】要🙉怎么🙊实现!!!
UI 提供的【progress-step】要🙉怎么🙊实现!!!
90 0
Qt-QML-给我的导航条写一个动画-State-Transition
上篇中,我已经写出一个导航条的,虽然太丑了,不过功能是有了,这次我将要给我的导航条加一个动画,先看下演示效果
179 0
Qt-QML-给我的导航条写一个动画-State-Transition