业余码农学Python-16:简单文本进度条制作

业余码农学Python-16:简单文本进度条制作

学Python这么多天,除了之前的海龟画图之外,最近学的一个实例算是让我再一次感受到成就感:一个每次安装程序都能见到的实例——进度条。

进度条在计算机使用中可以说是随处可见,是每一个接触过电脑的人都知道的东西,但是这个玩意儿看似简单,学过之后才发现,进度条竟然也有些许隐藏的套路

一、进度条简单介绍

  • 进度条从呈现形式有多种多样,有的设计非常漂亮、色彩丰富;
业余码农学Python-16:简单文本进度条制作

  • 深入研究进度条的进度展示函数是才发现也是套路满满

(界面显示的进度大部分都不是采用线性方法计算出来,直白点讲就是实际进度和显示进度多数都是不一致的。下图是主流的几种显示进度的计算函数)。

业余码农学Python-16:简单文本进度条制作

二、文本进度条实例

话不多说,上手实践,走起。因为初学,所以粗糙。只能先来个最糙的文本进度条(不忽悠,线性时间展示)。

  • 实例目标:

采用字符串方式打印可以动态变化的文本进度条,进度条在一行中逐渐变化

  • 问题分析:

借鉴大象进冰箱的步骤,这个问题我们也来分三步。第一步,实现计时;第二步,展示每一次进度;第三步,把每一次的进度展示整到一行里面。下面我们开始:

  • 第一步,实现计时
<code>import time  #导入time库
start = time.perf_counter() #计时开始
end = time.perf_counter() #计时结束
dur = end -start #计算时间差
print(dur) #输出/<code>
  • 第二步,展示每一次进度;

要展示每一次进度,我们需要引入一个过程(取一个最简单的函数,我们采用for循环,每次循环我们让时间延迟0.1秒)

<code>import time  #导入time库
start = time.perf_counter() #计时开始
for i in range(50): #循环50次
time.sleep(0.1) #延迟0.1秒
end = time.perf_counter() #计时结束
dur = end -start #计算时间差
print("{:.2f}".format(dur)) #输出/<code>

运行后,分50次输出程序运营时间。但没有展示我们需要的进度。改进一下

<code>#文本进度条
import time #导入time库
start = time.perf_counter() #计时开始
for i in range(51): #循环51次
time.sleep(0.1) #延迟1秒
end = time.perf_counter() #计时结束
dur = end -start #计算时间差
a="*"*i
b="-"*(50-i)
c=(i/50)*100
print("{:.0f}%[{}>{}]用时{:.2f}秒".format(c,a,b,dur)) #输出/<code>

显示50行和数据,效果如下,感觉还可以,基本实现,我们预期。

业余码农学Python-16:简单文本进度条制作

  • 第三步:把每一次的进度展示整到一行里面。50行并一行,单行刷新。

这里我们采用Python字符串处理中的转义符“\\r”来使单行打印结束后,光标移回行首,已实现单行数据刷新效果。

<code>#文本进度条
import time #导入time库
start = time.perf_counter() #计时开始
for i in range(51): #循环51次
time.sleep(0.1) #延迟0.1秒
end = time.perf_counter() #计时结束
dur = end -start #计算时间差
a="*"*i
b="-"*(50-i)
c=(i/50)*100
print("\\r{:.0f}%[{}>{}]用时{:.2f}秒".format(c,a,b,dur),end="") #输出/<code>

完美展示我们想要的结果:

业余码农学Python-16:简单文本进度条制作

  • 最后我们稍加改进,提示开始,进度条更新,提示结束。
<code>#文本进度条
print("执行开始".center(64,"-"))
import time #导入time库
start = time.perf_counter() #计时开始
for i in range(51): #循环51次
time.sleep(0.1) #延迟0.1秒
end = time.perf_counter() #计时结束
dur = end -start #计算时间差
a="*"*i
b="-"*(50-i)
c=(i/50)*100
print("\\r{:.0f}%[{}>{}]用时{:.2f}秒".format(c,a,b,dur),end="") #输出
print("\\n"+"执行结束".center(64,"-"))/<code>

更加完美展示我们想要的结果:

业余码农学Python-16:简单文本进度条制作

最后的成就感

换一个黑白条的展示方式,结果超出我的预期

<code>#文本进度条
print("执行开始".center(63,"-"))
import time #导入time库
start = time.perf_counter() #计时开始
for i in range(51): #循环51次
time.sleep(0.1) #延迟0.1秒
end = time.perf_counter() #计时结束
dur = end -start #计算时间差
a="■"*i
b="□"*(50-i)
c=(i/50)*100
print("\\r{:.0f}%[{}{}]用时{:.2f}秒".format(c,a,b,dur),end="") #输出
print("\\n"+"执行结束".center(63,"-"))/<code>
  • 这个结果就是我想要的,我喜欢。成就感满满!!
业余码农学Python-16:简单文本进度条制作


【end】


分享到:


相關文章: