Lesson 030 —— time 模块
time 模块及方法介绍。
time
用于格式化日期和时间。时间间隔是以秒为单位的浮点小数。
-
时间戳
每个时间戳都以自从1970年1月1日午夜(历元)经过了多长时间来表示。
time.time()
用来获取当前时间戳。时间戳单位最适于做日期运算。但是1970年之前的日期就无法以此表示了。太遥远的日期也不行,UNIX和Windows只支持到2038年。 -
格式化(结构化)时间
很多Python函数用一个元组装起来的9组数字处理时间。
time.localtime()
返回当地时间的时间元组time.struct_time(tm_year=2018, tm_mon=11, tm_mday=12, tm_hour=20, tm_min=18, tm_sec=30, tm_wday=0, tm_yday=316, tm_isdst=0)
。向此函数传递时间戳可以转换为时间元组的形式。time.gmtime()
返回格林尼治时间(比我们慢八个小时,隔着八个时区)。import time localtime = time.localtime(time.time()) print ("本地时间为 :", localtime) # 结果 本地时间为 : time.struct_time(tm_year=2018, tm_mon=11, tm_mday=12, tm_hour=20, tm_min=18, tm_sec=30, tm_wday=0, tm_yday=316, tm_isdst=0)
时间元组的属性如下:
序号 属性 值 0 tm_year 2018 1 tm_mon 1 到 12 2 tm_mday 1 到 31 3 tm_hour 0 到 23 4 tm_min 0 到 59 5 tm_sec 0 到 61 (60或61 是闰秒) 6 tm_wday 0到6 (0是周一) 7 tm_yday 一年中的第几天,1 到 366 8 tm_isdst 是否为夏令时,值有:1(夏令时)、0(不是夏令时)、-1(未知),默认 -1 -
字符串时间
使用
time.strftime("%Y-%m-%d %H:%M:%S", time.localtime())
返回字符串形式的时间。三种格式之间的转换方式如下:
030-01其中
strftime
时间日期格式化符号:-
%y
两位数的年份表示(00-99) -
%Y
四位数的年份表示(000-9999) -
%m
月份(01-12) -
%d
月内中的一天(0-31) -
%H
24小时制小时数(0-23) -
%I
12小时制小时数(01-12) -
%M
分钟数(00=59) -
%S
秒(00-59) -
%a
本地简化星期名称 -
%A
本地完整星期名称 -
%b
本地简化的月份名称 -
%B
本地完整的月份名称 -
%c
本地相应的日期表示和时间表示 -
%j
年内的一天(001-366) -
%p
本地A.M.或P.M.的等价符 -
%U
一年中的星期数(00-53)星期天为星期的开始 -
%w
星期(0-6),星期天为星期的开始 -
%W
一年中的星期数(00-53)星期一为星期的开始 -
%x
本地相应的日期表示 -
%X
本地相应的时间表示 -
%Z
当前时区的名称 -
%%
百分号%
号本身
图片显示如下:
030-02 -
-
time 模块内置方法
序号 方法 描述 1 time.altzone 返回格林威治西部的夏令时地区的偏移秒数。如果该地区在格林威治东部会返回负值(如西欧,包括英国)。对夏令时启用地区才能使用。 2 time.asctime([tupletime]) 接受时间元组并返回一个可读的形式为"Tue Dec 11 18:07:14 2008"(2008年12月11日 周二18时07分14秒)的24个字符的字符串。 3 [time.clock() 用以浮点数计算的秒数返回当前的CPU时间。用来衡量不同程序的耗时,比time.time()更有用。由于该方法依赖操作系统,在 3.8 版本中被移除,使用下列两个函数替代。 time.perf_counter() # 返回系统运行时间 time.process_time() # 返回进程运行时间
4 time.ctime([secs]) 作用相当于asctime(localtime(secs)),未给参数相当于asctime() 5 time.gmtime([secs]) 接收时间辍(1970纪元后经过的浮点秒数)并返回格林威治天文时间下的时间元组t。注:t.tm_isdst始终为0 6 time.localtime([secs]) 接收时间辍(1970纪元后经过的浮点秒数)并返回当地时间下的时间元组t(t.tm_isdst可取0或1,取决于当地当时是不是夏令时)。 7 time.mktime(tupletime) 接受时间元组并返回时间辍(1970纪元后经过的浮点秒数)。 8 time.sleep(secs) 推迟调用线程的运行,secs指秒数。 9 time.strftime(fmt[,tupletime]) 接收以时间元组,并返回以可读字符串表示的当地时间,格式由fmt决定。 10 time.strptime(str,fmt='%a %b %d %H:%M:%S %Y') 根据 fmt 的格式把一个时间字符串解析为时间元组。 11 time.time( ) 返回当前时间的时间戳(1970纪元后经过的浮点秒数)。 12 time.tzset() 根据环境变量TZ重新初始化时间相关设置。 13 time.perf_counter() 返回计时器的精准时间(系统的运行时间),包含整个系统的睡眠时间。由于返回值的基准点是未定义的,所以,只有连续调用的结果之间的差才是有效的。 14 time.process_time() 返回当前进程执行 CPU 的时间总和,不包含睡眠时间。由于返回值的基准点是未定义的,所以,只有连续调用的结果之间的差才是有效的。 -
重要属性
序号 属性 描述 1 time.timezone 属性time.timezone是当地时区(未启动夏令时)距离格林威治的偏移秒数(>0,美洲;<=0大部分欧洲,亚洲,非洲)。 2 time.tzname 属性time.tzname包含一对根据情况的不同而不同的字符串,分别是带夏令时的本地时区名称,和不带的。
datetime
datetime 模块用于是date和time模块的合集,datetime 模块定义了5个类,分别是:
-
datetime.date:表示日期的类
-
datetime.datetime:表示日期时间的类
-
datetime.time:表示时间的类
-
datetime.timedelta:表示时间间隔,即两个时间点的间隔
-
datetime.tzinfo:时区的相关信息
网友评论