Python入门之time模块
time模块中时间表现的格式主要有三种:
- timestamp时间戳,时间戳表示的是从1970年1月1日00:00:00开始按秒计算的偏移量
- struct_time时间元组,共有九个元素组。
- 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 格式
备注:
- “%p”只有与“%I”配合使用才有效果。
- 文档中强调确实是0 - 61,而不是59,闰年秒占两秒(汗一个)。
- 当使用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
***********************************************************
学习永远不晚。——高尔基
***********************************************************

浙公网安备 33010602011771号