在Python中,与时间处理有关的模块就包括:time,datetime以及calendar。这篇文章,主要讲解time模块。
日期时间基本知识
- 在Python中,通常有这几种方式来表示时间:
- 时间戳
- 格式化的时间字符串
- 元组(struct_time)共九个元素
由于Python的time模块实现主要调用C库,所以各个平台可能有所不同。
- UTC(Coordinated Universal Time,世界协调时)亦即格林威治天文时间,世界标准时间。在中国为UTC+8。DST(Daylight Saving Time)即夏令时。
- 时间戳(timestamp)的方式:通常来说,时间戳表示的是从1970年1月1日00:00:00开始按秒计算的偏移量。我们运行
type(time.time())
,返回的是float类型。返回时间戳方式的函数主要有time(),clock()等。 - 元组(struct_time)方式:struct_time元组共有9个元素,返回struct_time的函数主要有gmtime(),localtime(),strptime()。下面列出这种方式元组中的几个元素:
索引 | 属性 | 值 |
---|---|---|
0 | tm_year(年) | 比如:2011 |
1 | tm_mon(月) | 1-12 |
函数说明
1) time.localtime([secs]):将一个时间戳转换为当前时区的struct_time。secs参数未提供,则以当前时间为准。
>>> time.localtime()
time.struct_time(tm_year=2011, tm_mon=5, tm_mday=5, tm_hour=14, tm_min=14, tm_sec=50, tm_wday=3, tm_yday=125, tm_isdst=0)
>>> time.localtime(1304575584.1361799)
time.struct_time(tm_year=2011, tm_mon=5, tm_mday=5, tm_hour=14, tm_min=6, tm_sec=24, tm_wday=3, tm_yday=125, tm_isdst=0)
2)time.gmtime(****[secs]****)**:和localtime()方法类似,gmtime()方法是将一个时间戳转换为UTC时区(0时区)的struct_time。
>>>time.gmtime()
time.struct_time(tm_year=2011, tm_mon=5, tm_mday=5, tm_hour=6, tm_min=19, tm_sec=48, tm_wday=3, tm_yday=125, tm_isdst=0)
3)time.time():返回当前时间的时间戳。
>>> time.time()
1304575584.1361799
4)time.mktime(t)**:将一个struct_time转化为时间戳。
>>> time.mktime(time.localtime())
1304576839.0
5)time.sleep(secs):线程推迟指定的时间运行。单位为秒。
6)time.clock():这个需要注意,在不同的系统上含义不同**。在UNIX系统上,它返回的是“进程时间”,它是用秒表示的浮点数(时间戳)。而在WINDOWS中,第一次调用,返回的是进程运行的实际时间。而第二次之后的调用是自第一次调用以后到现在的运行时间。(实际上是以WIN32上QueryPerformanceCounter()为基础,它比毫秒表示更为精确)
import time
if __name__ == '__main__':
time.sleep(1)
print "clock1:%s" % time.clock()
time.sleep(1)
print "clock2:%s" % time.clock()
time.sleep(1)
print "clock3:%s" % time.clock()
运行结果:
clock1:3.35238137808e-006
clock2:1.00004944763
clock3:2.00012040636
7)time.asctime([t]):把一个表示时间的元组或者struct_time表示为这种形式:'Sun Jun 20 23:21:05 1993'**。如果没有参数,将会将time.localtime()作为参数传入。
>>> time.asctime()'Thu May 5 14:55:43 2011'
8)time.ctime([secs])**:把一个时间戳(按秒计算的浮点数)转化为time.asctime()的形式。如果参数未给或者为None的时候,将会默认time.time()为参数。它的作用相当于
time.asctime(time.localtime(secs))。
>>> time.ctime()'Thu May 5 14:58:09 2011'
>>> time.ctime(time.time())'Thu May 5 14:58:39 2011'
>>> time.ctime(1304579615)'Thu May 5 15:13:35 2011'
9)time.strftime(format[, t])**:把一个代表时间的元组或者struct_time(如由time.localtime()和time.gmtime()返回)转化为格式化的时间字符串。如果t未指定,将传入time.localtime()。如果元组中任何一个元素越界,ValueError的错误将会被抛出。
备注:
“%p”只有与“%I”配合使用才有效果。
文档中强调确实是0 - 61,而不是59,闰年秒占两秒(汗一个)。
当使用strptime()函数时,只有当在这年中的周数和天数被确定的时候%U和%W才会被计算。
举个例子:
>>> time.strftime("%Y-%m-%d %X", time.localtime())'2011-05-05 16:37:06'
10)time.strptime(string[, format])**:把一个格式化时间字符串转化为struct_time。实际上它和strftime()是逆操作。
>>> time.strptime('2011-05-05 16:37:06', '%Y-%m-%d %X')
time.struct_time(tm_year=2011, tm_mon=5, tm_mday=5, tm_hour=16, tm_min=37, tm_sec=6, tm_wday=3, tm_yday=125, tm_isdst=-1)
在这个函数中,format默认为:"%a %b %d %H:%M:%S %Y"。
最后,我们来对time模块进行一个总结。
根据之前描述,在Python中共有三种表达方式:1)timestamp 2)tuple或者struct_time 3)格式化字符串。
官方文档翻译3.5.1
time-时间获取和转化
这个模块提供了一些与时间相关的方法.更多相关功能请参考datetime
和calendar
模块.
虽然这个模块一直都可用,但并不是所有方法都可以在所有平台上都可用.在这个模块中大多数方法是调用C语言的同名库.有时侯参考平台文档更有用,因为一些方法的语义随平台不同而不同.
下面是一些技术解释和约定:
- 纪云是一个时间开始的地方.'0'意味着某年1月1日零点,在Unix上是1970年,使用
gmtime(0)
来获取这个纪云.
>>> import time
>>> time.gmtime(0)
time.struct_time(tm_year=1970, tm_mon=1, tm_mday=1, tm_hour=0, tm_min=0, tm_sec=0, tm_wday=3, tm_yday=1, tm_isdst=0)
- 此模块中的方法可能无法处理纪元前或遥远的未来的日期和时间.更远未来分界点是由C库决定的,对于32位系统来说,典型的是2038年.
- 2000年问题(y2k),Python依赖于C语言库,一般来说没有2000年问题,因为所有的日期和时间在内部表示为自纪元秒.方法
strptime()
使用%y格式可以解析2位数的年份。当2位数字的年份被解析,他们是根据POSIX和ISO C标准转换:值69-99被映射到1969年至1999年,值0-68被映射到2000至2068年。 - UTC是代表世界时间(前身为格林威治时间,或GMT)。缩写UTC是不是一个错误,它是英语和法语之间的妥协.
- DST是夏令时,(通常情况下)在不同时区调整一年中的小时。 DST规则是魔术(由当地法律确定),可以每年都在变化。 C库有一个包含本地规则的表(通常是从灵活的系统文件中读取),是真正的智慧在这方面的唯一来源。
- 各种实时函数的精确度可能小于由其中它们的值或参数所表示的单位。 例如。在大多数Unix系统中,时钟“滴答”只有50或100次。
- 另一方面,
time()
和sleep()
精度要优于Unix,时间被表示为否点数,time()
返回最精确时间(使用Unix的gettimeofday()
如果有的话),sleep()
接受一个非零的分数(Unix使用select()来实现,如果有的话). - 时间值是由gmtime()
,localtime()
, strptime()
,和通过传递参数 asctime()
, mktime()
and strftime()
的方法返回的9个序列. gmtime()
, localtime()
, 和strptime()
的返回值也提供各个字段名属性.
请参考struct_time
对象描述.
Changed in version 3.3:struct_time
扩展提供了tm_gmtoff
和tm_zone
属性当平台支持相应的struct tm
成员时. - 使用下面的函数转换:
这个模块定义了如下方法和数据项: