Python之time模块

在开始之前,首先要说明这几点:

  1. 在Python中,通常有这几种方式来表示时间:1)时间戳(timestamp) 2)格式化的时间字符串(format_string) 3)结构化时间(struct_time)

  2. UTC(Coordinated Universal Time,世界协调时)亦即格林威治天文时间,世界标准时间。在中国为UTC+8。DST(Daylight Saving Time)即夏令时。
  3. 时间戳(timestamp)的方式:通常来说,时间戳表示的是从1970年1月1日00:00:00开始按秒计算的偏移量。我们运行“type(time.time())”,返回的是float类型。返回时间戳方式的函数主要有time(),clock()等。
  4. 结构化时间(struct_time)方式:struct_time元组共有9个元素,返回struct_time的函数主要有gmtime(),localtime(),strptime()。

time模块中常用的几个函数:

  1. time.localtime([secs]):将一个时间戳转换为当前时区的结构化时间struct_time。secs参数未提供,则以当前时间为准。
>>> time.localtime()
time.struct_time(tm_year=2018, tm_mon=9, tm_mday=14, tm_hour=15, tm_min=1, tm_sec=44, tm_wday=4, tm_yday=257, tm_isdst=0)

>>> time.localtime(1535485415)
time.struct_time(tm_year=2018, tm_mon=8, tm_mday=29, tm_hour=3, tm_min=43, tm_sec=35, tm_wday=2, tm_yday=241, tm_isdst=0)

  结构化时间中的属性含义:

  tm_year:年, tm_mon:月, tm_mday:日, tm_hour:时, tm_min:分, tm_sec:秒, tm_wday:星期(0-6,周日为0), tm_yday:今年第几天, tm_isdst:是否夏令时

         2. time.gmtime([secs]):和localtime()方法类似,gmtime()方法是将一个时间戳转换为UTC时区(0时区)的struct_time

>>> time.gmtime()
time.struct_time(tm_year=2018, tm_mon=9, tm_mday=14, tm_hour=7, tm_min=14, tm_sec=54, tm_wday=4, tm_yday=257, tm_isdst=0)

    3. time.time():返回当前时间的时间戳。

>>> time.time()
1536909364.427116

   4. time.mktime(t):将一个struct_time转化为时间戳

>>> time.mktime(time.localtime())
1536909431.0

   5. time.sleep(secs):线程推迟指定的时间运行。单位为秒。

>>> n=0
>>> while not n:
    n=1
    a=time.time()
    time.sleep(1)
    b=time.time()
    print(b-a)

    
1.00480318069458

   6. time.clock():这个需要注意,在不同的系统上含义不同。在UNIX系统上,它返回的是“进程时间”,它是用秒表示的浮点数(时间戳)。而在WINDOWS中,第一次调用,返回的是进程运行的实际时间。而第二次之后的调用是自第一次调用以后到现在的运行时间。(实际上是以WIN32上QueryPerformanceCounter()为基础,它比毫秒表示更为精确)

>>> n=0
>>> while not n:
    n = 1
    a1 = time.clock()  #第一次调用time.clock()
    time.sleep(1)
    a2 = time.clock() #第二次调用time.clock()
    time.sleep(1)
    a3 = time.clock() #第三次调用time.clock()

    
>>> a1
3.909741658932709e-06  #时间戳
>>> a2
0.9943924530256758   #距时间戳时长
>>> a3
2.007640123919262  #距时间戳时长

   7. time.asctime([t]):把一个表示时间的元组或者struct_time表示为这种形式:'Sun Jun 20 23:21:05 1993'。如果没有参数,将会将time.localtime()作为参数传入。

>>> time.asctime()
'Fri Sep 14 17:09:35 2018'

   8. time.ctime([secs]):把一个时间戳(按秒计算的浮点数)转化为time.asctime()的形式。如果参数未给或者为None的时候,将会默认time.time()为参数。它的作用相当于time.asctime(time.localtime(secs))。

>>> time.ctime()
'Fri Sep 14 17:11:09 2018'

   9. time.strftime(format[, t]):把一个代表时间的元组或者struct_time(如由time.localtime()和time.gmtime()返回)转化为格式化的时间字符串。如果t未指定,将传入time.localtime()。如果元组中任何一个元素越界,ValueError的错误将会被抛出。

>>> time.strftime("%Y-%m-%d %X", time.localtime())
'2018-09-14 17:13:59'

 

格式含义备注
%a 本地(locale)简化星期名称  
%A 本地完整星期名称  
%b 本地简化月份名称  
%B 本地完整月份名称  
%c 本地相应的日期和时间表示  
%d 一个月中的第几天(01 - 31)  
%H 一天中的第几个小时(24小时制,00 - 23)  
%I 第几个小时(12小时制,01 - 12)  
%j 一年中的第几天(001 - 366)  
%m 月份(01 - 12)  
%M 分钟数(00 - 59)  
%p 本地am或者pm的相应符
%S 秒(01 - 61)
%U 一年中的星期数。(00 - 53星期天是一个星期的开始。)第一个星期天之前的所有天数都放在第0周。
%w 一个星期中的第几天(0 - 6,0是星期天)
%W 和%U基本相同,不同的是%W以星期一为一个星期的开始。  
%x 本地相应日期  
%X 本地相应时间  
%y 去掉世纪的年份(00 - 99)  
%Y 完整的年份  
%Z 时区的名字(如果不存在为空字符)  
%% ‘%’字符  

备注:

  1. “%p”只有与“%I”配合使用才有效果。

  2. 文档中强调确实是0 - 61,而不是59,闰年秒占两秒(汗一个)。

  3. 当使用strptime()函数时,只有当在这年中的周数和天数被确定的时候%U和%W才会被计算。

   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"。

 

总结:

三种时间表达方式的转换关系如下:

 

posted @ 2018-09-14 17:26  恋853雨  阅读(189)  评论(0编辑  收藏  举报