-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("------执行结束------")
运行结果:
单行进度刷新:
-刷新的本质是:用后打印的字符覆盖之前的字符
-不能换行: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不换行,为了美观,输出执行结束前加换行符