time 模块 – 时间获取和转换 time 模块提供各种时间相关的功能 在 Python 中,与时间处理有关的模块包括:time,datetime 以及 calendar
必要说明:
虽然这个模块总是可用,但并非所有的功能都适用于各个平台。该模块中定义的大部分函数是调用 C 平台上的同名函数实现,所以各个平台上实现可能略有不同。一些术语和约定的解释:
时间戳(timestamp)的方式:通常来说,时间戳表示的是从 1970 年 1 月 1 日 00:00:00 开始按秒计算的偏移量(time.gmtime(0))此模块中的函数无法处理 1970 纪元年以前的日期和时间或太遥远的未来(处理极限取决于 C 函数库,对于 32 位系统来说,是 2038 年)UTC(Coordinated Universal Time,世界协调时)也叫格林威治天文时间,是世界标准时间。在中国为 UTC+8DST(Daylight Saving Time)即夏令时的意思一些实时函数的计算精度可能低于它们建议的值或参数,例如在大部分 Unix 系统,时钟一秒钟“滴答”50~100 次时间元祖(time.struct_time): gmtime(),localtime() 和 strptime() 以时间元祖(struct_time)的形式返回。
索引值(Index)属性(Attribute)值(Values)0tm_year(年)(例如:2015)1tm_mon(月)1 ~ 122tm_mday(日)1 ~ 313tm_hour(时)0 ~ 234tm_min(分)0 ~ 595tm_sec(秒)0 ~ 61(见下方注1)6tm_wday(星期几)0 ~ 6(0 表示星期一)7tm_yday(一年中的第几天)1 ~ 3668tm_isdst(是否为夏令时)0, 1, -1(-1 代表夏令时)注1:范围真的是 0 ~ 61(你没有看错哦_);60 代表闰秒,61 是基于历史原因保留。
time.altzone 返回格林威治西部的夏令时地区的偏移秒数;如果该地区在格林威治东部会返回负值(如西欧,包括英国);对夏令时启用地区才能使用。
time.asctime([t]) 接受时间元组并返回一个可读的形式为"Tue Dec 11 18:07:14 2015"(2015年12月11日 周二 18时07分14秒)的 24 个字符的字符串。
time.clock() 用以浮点数计算的秒数返回当前的 CPU 时间。用来衡量不同程序的耗时,比 time.time() 更有用。
Python 3.3 以后不被推荐,由于该方法依赖操作系统,建议使用 perf_counter() 或 process_time() 代替(一个返回系统运行时间,一个返回进程运行时间,请按照实际需求选择)
time.ctime([secs]) 作用相当于 asctime(localtime(secs)),未给参数相当于 asctime()
time.gmtime([secs]) 接收时间辍(1970 纪元年后经过的浮点秒数)并返回格林威治天文时间下的时间元组 t(注:t.tm_isdst 始终为 0)
time.daylight 如果夏令时被定义,则该值为非零。
time.localtime([secs]) 接收时间辍(1970 纪元年后经过的浮点秒数)并返回当地时间下的时间元组 t(t.tm_isdst 可取 0 或 1,取决于当地当时是不是夏令时)
time.mktime(t) 接受时间元组并返回时间辍(1970纪元后经过的浮点秒数)
time.perf_counter() 返回计时器的精准时间(系统的运行时间),包含整个系统的睡眠时间。由于返回值的基准点是未定义的,所以,只有连续调用的结果之间的差才是有效的。
time.process_time() 返回当前进程执行 CPU 的时间总和,不包含睡眠时间。由于返回值的基准点是未定义的,所以,只有连续调用的结果之间的差才是有效的。
time.sleep(secs) 推迟调用线程的运行,secs 的单位是秒。
time.strftime(format[, t]) 把一个代表时间的元组或者 struct_time(如由 time.localtime() 和 time.gmtime() 返回)转化为格式化的时间字符串。如果 t 未指定,将传入 time.localtime()。如果元组中任何一个元素越界,将会抛出 ValueError 异常。
format 格式如下:
格式含义备注%a本地(locale)简化星期名称%A本地完整星期名称%b本地简化月份名称%B本地完整月份名称%c本地相应的日期和时间表示%d一个月中的第几天(01 - 31)%H一天中的第几个小时(24 小时制,00 - 23)%l一天中的第几个小时(12 小时制,01 - 12)%j一年中的第几天(001 - 366)%m月份(01 - 12)%M分钟数(00 - 59)%p本地 am 或者 pm 的相应符注1%S秒(01 - 61)注2%U一年中的星期数(00 - 53 星期天是一个星期的开始)第一个星期天之前的所有天数都放在第 0 周注3%w一个星期中的第几天(0 - 6,0 是星期天)注3%W和 %U 基本相同,不同的是 %W 以星期一为一个星期的开始%x本地相应日期%X本地相应时间%y去掉世纪的年份(00 - 99)%Y完整的年份%z用 +HHMM 或 -HHMM 表示距离格林威治的时区偏移(H 代表十进制的小时数,M 代表十进制的分钟数)%Z时区的名字(如果不存在为空字符)%%%号本身注1:“%p”只有与“%I”配合使用才有效果。 注2:范围真的是 0 ~ 61(你没有看错哦_);60 代表闰秒,61 是基于历史原因保留。 注3:当使用 strptime() 函数时,只有当在这年中的周数和天数被确定的时候 %U 和 %W 才会被计算。
举个例子:
import time as t t.strftime(“a, %d %b %Y %H:%M:%S +0000”, t.gmtime()) ‘a, 24 Aug 2014 14:15:03 +0000’
time.strptime(string[, format]) 把一个格式化时间字符串转化为 struct_time。实际上它和 strftime() 是逆操作。
举个例子:
import time as t t.strptime(“30 Nov 14”, “%d %b %y”) time.struct_time(tm_year=2014, tm_mon=11, tm_mday=30, tm_hour=0, tm_min=0, tm_sec=0, tm_wday=6, tm_yday=334, tm_isdst=-1)
time.time() 返回当前时间的时间戳(1970 纪元年后经过的浮点秒数)
time.timezone time.timezone 属性是当地时区(未启动夏令时)距离格林威治的偏移秒数(美洲 >0;大部分欧洲,亚洲,非洲 <= 0)
time.tzname time.tzname 属性是包含两个字符串的元组:第一是当地非夏令时区的名称,第二个是当地的 DST 时区的名称
定时器例子:
import time as t class MyTimer(): def __init__(self): print("用start函数开始计时") print("用stop函数停止计时") self.unit = ['年','月','天','小时','分钟','秒'] self.prompt = "未开始计时" self.lasted = [] self.begin = 0 self.end = 0 def start(self): self.begin = t.localtime() print("开始计时...") def stop(self): self.end = t.localtime() self._calc() print("计时结束...") print(self.prompt) def _calc(self): self.prompt = "总共运行了" for index in range(6): self.lasted.append(self.end[index]-self.begin[index]) if self.lasted[index]: self.prompt += ( str(self.lasted[index]) + self.unit[index] ) def __add__(self, other): prompt = "总共运行了" result = [] for index in range(6): result.append(self.lasted[index]+other.lasted[index]) if result[index]: prompt += ( str(result[index]) + self.unit[index] ) print(prompt) >>> t1=MyTimer() >>>用start函数开始计时 >>>用stop函数停止计时 >>> t1.start() >>>开始计时... >>> t1.stop() >>>计时结束... >>>总共运行了4秒 >>> t2=MyTimer() >>>用start函数开始计时 >>>用stop函数停止计时 >>> t2.start() >>>开始计时... >>> t2.stop() >>>计时结束... >>>总共运行了8秒 >>> t1+t2 >>>总共运行了12秒