前言
在python中包含了最简单的处理时间的标准库,time库能够表达计算机时间,提供获取系统时间并格式化输出的方法,提供系统级精确计时功能。
time库包含三类函数,以下介绍常用的函数:
时间获取:time()、ctime()、gmtime()
时间格式化:strftime()、strptime()
程序计时:sleep()、perf_counter()
时间获取
函数 | 描述 |
---|---|
time() | 获取当前时间戳,即当前系统内表示时间的一个浮点数。 |
ctime() | 获取当前时间,并返回一个以人类可读方式的字符串。 |
gmtime() | 获取当前时间,并返回计算机可处理的时间格式。 |
import time
# 获取当前时间戳,即当前系统内表示时间的一个浮点数。
print("===========time()=================")
print(time.time())
# 获取当前时间,并返回一个以人类可读方式的字符串。
print("===========ctime()=================")
print(time.ctime())
# 获取当前时间,并返回计算机可处理的时间格式。
print("===========gmtime()=================")
print(time.gmtime())
输出结果:
===========time()=================
1598105489.9561064
===========ctime()=================
Sat Aug 22 22:11:29 2020
===========gmtime()=================
time.struct_time(tm_year=2020, tm_mon=8, tm_mday=22, tm_hour=14, tm_min=11, tm_sec=29, tm_wday=5, tm_yday=235, tm_isdst=0)
时间格式化
函数 | 描述 |
---|---|
strftime() | 按照一定格式把时间显示成所需要的效果,传入的值是时间元组。 |
timeStr() | 按照特定时间格式将字符串转换(解析)为时间类型,传入的值是字符串。 |
格式化字符串 | 日期/时间说明 | 取值范围 |
---|---|---|
%Y | 年份 | 0000~9999 |
%m | 月份(数字) | 01~12 |
%B | 月份(英文全称) | January~December |
%b | 月份(英文缩写) | Jan~Dec |
%d | 日期 | 01~31 |
%A | 星期(英文全称) | Monday~Sunday |
%a | 星期(英文缩写) | Mon~Sun |
%H | 小时(24小时制) | 00~23 |
%I | 小时(12小时制) | 01~12 |
%p | 上/下午 | AM,PM |
%M | 分钟 | 00~59 |
%S | 秒 | 00~59 |
import time
# strftime()是格式化模板字符串,用来定义输出效果,说白了就是按照一定格式把时间显示成所需要的效果,传入的值是时间元组。
print("===========strptime()=================")
t=time.gmtime()
print( time.strftime("%Y-%m-%d %H:%M:%S",t))
# strptime()按照特定时间格式将字符串转换(解析)为时间类型,传入的值是字符串。
print("===========strptime()=================")
timeStr='2018-01-26 12:55:20'
print(time.strptime(timeStr,"%Y-%m-%d %H:%M:%S"))
结果:
===========strptime()=================
2020-08-22 14:11:29
===========strptime()=================
time.struct_time(tm_year=2018, tm_mon=1, tm_mday=26, tm_hour=12, tm_min=55, tm_sec=20, tm_wday=4, tm_yday=26, tm_isdst=-1)
程序计时
程序计时指测量起止动作所经历时间的过程,主要包括测量时间和产生时间两部分。time库提供了一个非常精准的测量时间函数perf_counter(),该函数可以获取CPU以其频率运行的时钟,这个时间往往是以纳秒来计算的,所以这样获取的时间非常精准。另外产生时间函数sleep(),它可以让程序休眠或产生一段时间。
函数 | 描述 |
---|---|
perf_counter() | 返回一个CPU级别的精确时间计数值,单位为秒。由于这个计数值起点不确定,连续调用求差值才有意义。 |
sleep(s) | s为休眠时间,单位秒,可以是浮点数。 |
import time
# 得到开始时间
print("===========perf_counter()=================")
startTime=time.perf_counter()
print(startTime)
# 得到结束时间
endTime=time.perf_counter()
print(endTime)
# 开始时间-结束时间
print(endTime-startTime)
# 等待
def wait():
print("===========time.sleep(3.3)=================")
print(time.time())
time.sleep(3.3)
print("过去了3.3秒")
print(time.time())
wait()
输出:
===========perf_counter()=================
0.0322414
0.0323797
0.00013829999999999398
===========time.sleep(3.3)=================
1598105489.9751248
过去了3.3秒
1598105493.2761245
那么下面我们做一个小测试,将当前时间转换成指定格式字符串再转换成时间戳。
需求:
- 获取当前时间戳
- 转换成指定格式字符串
- 转换成时间戳
# 导入时间库
import time
# 需要注意的是不能使用时间戳,需要将时间戳转换成时间元组,才能调用strftime()方法,strptime()方法返回的也是元组
# 使用localtime()方法将时间戳转换成时间元组
timestamp=time.time()
print("=============我是时间戳timestamp==================\n %s" % timestamp)
time_tuple=time.localtime(timestamp)
print("=============我是时间元组time_tuple==================\n %s" % str(time_tuple))
# 使用strftime()方法将时间元组转换成指定样式字符串
time_str=time.strftime("%Y年%m月%d日 %H时%M分%S秒",time_tuple)
print("=============我是指定样式字符串time_str==================\n %s" % time_str)
# 使用strptime()方法将指定样式字符串转换成时间元组
time_tuple2=time.strptime(time_str,"%Y年%m月%d日 %H时%M分%S秒")
print("=============我是时间元组time_tuple2==================\n %s" % str(time_tuple))
# 使用mktime()方法将时间元组转换成时间戳
timestamp2=time.mktime(time_tuple2)
print("=============我是时间戳timestamp2==================\n %s" % timestamp2)
输出:
=============我是时间戳timestamp==================
1598110710.4706056
=============我是时间元组time_tuple==================
time.struct_time(tm_year=2020, tm_mon=8, tm_mday=22, tm_hour=23, tm_min=38, tm_sec=30, tm_wday=5, tm_yday=235, tm_isdst=0)
=============我是指定样式字符串time_str==================
2020年08月22日 23时38分30秒
=============我是时间元组time_tuple2==================
time.struct_time(tm_year=2020, tm_mon=8, tm_mday=22, tm_hour=23, tm_min=38, tm_sec=30, tm_wday=5, tm_yday=235, tm_isdst=0)
=============我是时间戳timestamp2==================
1598110710.0