python学习笔记(5)-time库的使用

import time

一、时间获取函数

time(), ctime(),gmtime()

>>> import time
>>> time.time()
1524297783.3058376
>>> time.ctime()
'Sat Apr 21 16:03:09 2018'
>>> time.gmtime()
time.struct_time(tm_year=2018, tm_mon=4, tm_mday=21, tm_hour=8, tm_min=4, tm_sec=6, tm_wday=5, tm_yday=111, tm_isdst=0)

二、时间格式化

strftime(tpl, ts)  tpl是时间格式化模板字符串,用来定义输出效果,ts是计算机内部时间类型变量。

>>> t=time.gmtime()
>>> time.strftime("%Y-%m-%d %H:%M:%S", t)
'2018-04-21 08:05:49'
%Y   年份
%m  月份
%B   月份名称 January
%b   月份名称缩写  Jan
%d   日期
%A   星期 Monday
%a   星期缩写 Mon
%H   小时 24
%h   小时 12
%p   上下午
%M  分钟
%S   秒

举例如下:

>>> time.strftime("%Y-%B-%d-%A-%H-%p-%S")
'2018-April-21-Saturday-16-PM-10'
>>> time.strftime("%A-%p")
'Saturday-PM'
>>> time.strftime("%M:%S")
'15:39'
>>> time.strftime("%M:%S")
'15:45'
>>> time.strftime("%M:%S",t)
'05:49'

如果strftime没有第二个参数,则默认获取当前时间。

strptime(timestr, "%Y-%m-%d %H:%M:%S")  根据时间字符串以及格式化输出,转换成结构体。

>>> timestr
'2018-01-26 12:55:33'
>>> time.strptime(timestr,"%Y-%m-%d %H:%M:%S")
time.struct_time(tm_year=2018, tm_mon=1, tm_mday=26, tm_hour=12, tm_min=55, tm_sec=33, tm_wday=4, tm_yday=26, tm_isdst=-1)

三、程序计时

测量时间:perf_counter()  返回一个CPU级别的精确时间计数值,单位为妙,由于这个计数值起点不确定,连续调用使用差值才有意义。

>>> start=time.perf_counter()
>>> start
3.9111116077602044e-06
>>> end=time.perf_counter()
>>> end
10.212393474589648
>>> end - start
10.212389563478041

产生时间:sleep(s) s妙的休眠时间,可以是浮点数,如time.sleep(3.5)

如下有一个时间进度条的实例:

#TextProBarV3.py
import time
scale = 50
print("start".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="")  '''这里\r,光标回到行首, end=“”表示不输出空格,字符串连续输出'''
        time.sleep(0.1)
print("\n"+"end".center(scale//2,"-"))

 

posted @ 2018-04-21 16:51  行木辛  阅读(7893)  评论(0编辑  收藏  举报