Python入门之time模块

time模块中时间表现的格式主要有三种:

  1. timestamp时间戳,时间戳表示的是从1970年1月1日00:00:00开始按秒计算的偏移量
  2. struct_time时间元组,共有九个元素组。
  3. format time 格式化时间,已格式化的结构使时间更具可读性。包括自定义格式和固定格式。

1、python中3种时间格式转换关系:

2、time模块常用函数

    2.1 time.localtime([secs]):将一个时间戳转换为当前时区的struct_time。secs参数未提供,则以当前时间为准。

>>> time.localtime()
time.struct_time(tm_year=2017, tm_mon=7, tm_mday=24, tm_hour=21, tm_min=8, tm_sec=35, tm_wday=0, tm_yday=205, tm_isdst=0)
>>> time.localtime(12354.23124124)
time.struct_time(tm_year=1970, tm_mon=1, tm_mday=1, tm_hour=11, tm_min=25, tm_sec=54, tm_wday=3, tm_yday=1, tm_isdst=0)

    struct_time时间格式:

索引(Index)属性(Attribute)值(Values)
0  tm_year(年)  比如2011 
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
6  tm_wday(weekday)  0 - 6(0表示周日)
7  tm_yday(一年中的第几天)  1 - 366
8  tm_isdst(是否是夏令时)  默认为-1

 

 

 

 

 

 

    

 

 

 

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

>>> time.gmtime()
time.struct_time(tm_year=2017, tm_mon=7, tm_mday=24, tm_hour=13, tm_min=19, tm_sec=39, tm_wday=0, tm_yday=205, tm_isdst=0)

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

>>> time.time()
1500902543.3271477

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

>>> time.localtime()
time.struct_time(tm_year=2017, tm_mon=7, tm_mday=24, tm_hour=21, tm_min=23, tm_sec=4, tm_wday=0, tm_yday=205, tm_isdst=0)
>>> time.mktime(time.localtime())
1500902605.0

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

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

>>> def cl():
    import time
    time.sleep(1)
    print("clock1",time.clock())
    time.sleep(1)
    print("clock2",time.clock())
    time.sleep(1)
    print("clock3",time.clock())

    
>>> cl()
clock1 3052.703877825567
clock2 3053.764968736748
clock3 3054.783982442824

#其中第一个clock()输出的是程序运行时间;第二、三个clock()输出的都是与第一个clock的时间间隔

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

>>> time.asctime()
'Mon Jul 24 21:33:34 2017'

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

>>> time.ctime()
'Mon Jul 24 21:35:59 2017'
>>> time.ctime(time.time())
'Mon Jul 24 21:36:04 2017'
>>> time.ctime(12345.1235456)
'Thu Jan  1 11:25:45 1970'

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

>>> time.strftime("%Y-%m-%d %X", time.localtime())
'2017-07-24 21:42:57'

    2.10 time.strptime(string[, format]):把一个格式化时间字符串转化为struct_time。实际上它和strftime()是逆操作。

>>> time.strptime('2017-07-23 16:37:06', '%Y-%m-%d %X')
time.struct_time(tm_year=2017, tm_mon=7, tm_mday=23, tm_hour=16, tm_min=37, tm_sec=6, tm_wday=6, tm_yday=204, tm_isdst=-1)

    format time 格式

  备注:

  1. “%p”只有与“%I”配合使用才有效果。
  2. 文档中强调确实是0 - 61,而不是59,闰年秒占两秒(汗一个)。
  3. 当使用strptime()函数时,只有当在这年中的周数和天数被确定的时候%U和%W才会被计算。
格式含义
%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 时区的名字(如果不存在为空字符)
%% ‘%’字符

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

参考:http://www.cnblogs.com/qq78292959/archive/2013/03/22/2975786.html

 

***********************************************************

 学习永远不晚。——高尔基

***********************************************************

posted @ 2017-07-24 22:01  chengd  阅读(704)  评论(0)    收藏  举报