Python“文本进度条”——time库的使用

-time库是Python中处理时间的标准库
1)计算机时间的表达
2)提供获取系统时间并格式化输出功能
3)提供系统级精确计时功能,用于程序性能分析
import time
time.< b >()
-time库包含三类函数
1)时间获取:time()、ctime()、gmtime()
2)时间格式化:strftime()、strptime()

格式化字符串 日期/时间说明 值范围和实例
%Y 年份 0000~9999
%m 月份 01~12
%B 月份名称 January~December
%b 月份名称缩写 Jan~Dec
%A 星期 Monday~Sunday
%a 星期缩写 Mon~Sun
%H 小时(24h) 00~23
%I 小时(12h) 01~12
%p 上/下午 AM,PM
%M 分钟 00~59
%S 00~59

3)程序计时:sleep()、perf_counter()
-程序计时指测量起止动作所经历时间的过程

函数 描述
time() 获取当前时间戳,即计算机内部时间值,浮点数,如time.time()得1557904178.4358344,以秒为单位
ctime() 获取当前时间并以易读方式表示,返回字符串,如time.time()得’Wed May 15 15:11:30 2019’
gmtime() 获取当前时间,表示为计算机可处理的时间格式,如time.gmtime()得time.struct_time(tm_year=2019, tm_mon=5, tm_mday=15, tm_hour=7, tm_min=13, tm_sec=15, tm_wday=2, tm_yday=135, tm_isdst=0)
strftime(tpl,ts) tpl是格式化模板字符串,用来定义输出效果,ts是计算机内部时间类型变量,如t=time.gmtime() time.strftime("%Y-%m-%d %H:%M:%S",t) 得2019-05-15 07:17:38
strptime(str,tpl) str是字符串形式的时间值 tpl是格式化模板字符串,用来定义输入效果 timeStr=‘2019-05-15 07:17:38’ time.strptime(timeStr,"%Y-%m-%d %H:%M:%S") 得 time.struct_time(tm_year=2019, tm_mon=5, tm_mday=15, tm_hour=7, tm_min=17, tm_sec=38, tm_wday=2, tm_yday=135, tm_isdst=-1)
perf_counter() 返回一个CPU级别的精确时间计数值,单位为秒,由于这个计数值起点不确定,连续调用差值才有意义,如start=time.perf_counter() end=time.perf_counter() end-start
sleep(s) s拟休眠的时间,单位是秒,可以是浮点数

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

简单版:

import time
scale=10
print("------执行开始------")
for i in range(scale+1):
    a='*'*i  #将*复制i次
    b='.'*(scale-i) #将.赋值scale-i次
    c=(i/scale)*100 #输出进度条与当前进度相关的百分比
    print("{:^3.0f}%[{}->{}]".format(c,a,b))
    time.sleep(0.1)
print("------执行结束------")

运行结果:
Python“文本进度条”——time库的使用_第1张图片
单行进度刷新:
-刷新的本质是:用后打印的字符覆盖之前的字符
-不能换行:print()需要被控制
-要能回退:打印后光标退回到之前的位置\r

import time
for i in range(101):
    print("\r{:3}%".format(i),end="") #end=""可以改变每次输出换行的行为,使之不换行
    time.sleep(0.1)

运行结果:注意在IDLE中并不能看到单行刷新效果,而是所有信息都被打印出来,并不是程序错误。
在这里插入图片描述
完整版:

import time
scale=50
print("执行开始".center(scale//2,"-"))
start=time.perf_counter()
for i in range(scale+1):
    a='*'*i
    b='.'*(scale-i)
    c=(i/scale)*100
    dur=time.perf_counter()-start
    print("\r{:^3.0f}%[{}->{}]{:.2f}s".format(c,a,b,dur),end='')
    time.sleep(0.1)
print("\n"+"执行结束".center(scale//2,'-')) #因为for里print不换行,为了美观,输出执行结束前加换行符

Python“文本进度条”——time库的使用_第2张图片

你可能感兴趣的:(Python自学笔记)