Lesson 030 —— time 模块

2018-12-07  本文已影响0人  爱喵喵的鱼

Lesson 030 —— time 模块

time 模块及方法介绍。

time

用于格式化日期和时间。时间间隔是以秒为单位的浮点小数。

  1. 时间戳

    每个时间戳都以自从1970年1月1日午夜(历元)经过了多长时间来表示。time.time() 用来获取当前时间戳。时间戳单位最适于做日期运算。但是1970年之前的日期就无法以此表示了。太遥远的日期也不行,UNIX和Windows只支持到2038年。

  2. 格式化(结构化)时间

    很多Python函数用一个元组装起来的9组数字处理时间。time.localtime() 返回当地时间的时间元组 time.struct_time(tm_year=2018, tm_mon=11, tm_mday=12, tm_hour=20, tm_min=18, tm_sec=30, tm_wday=0, tm_yday=316, tm_isdst=0)。向此函数传递时间戳可以转换为时间元组的形式。time.gmtime() 返回格林尼治时间(比我们慢八个小时,隔着八个时区)。

    import time
    
    localtime = time.localtime(time.time())
    print ("本地时间为 :", localtime)
    
    # 结果
    本地时间为 : time.struct_time(tm_year=2018, tm_mon=11, tm_mday=12, tm_hour=20, tm_min=18, tm_sec=30, tm_wday=0, tm_yday=316, tm_isdst=0)
    

    时间元组的属性如下:

    序号 属性
    0 tm_year 2018
    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 (60或61 是闰秒)
    6 tm_wday 0到6 (0是周一)
    7 tm_yday 一年中的第几天,1 到 366
    8 tm_isdst 是否为夏令时,值有:1(夏令时)、0(不是夏令时)、-1(未知),默认 -1
  3. 字符串时间

    使用 time.strftime("%Y-%m-%d %H:%M:%S", time.localtime()) 返回字符串形式的时间。

    三种格式之间的转换方式如下:

    030-01

    其中 strftime 时间日期格式化符号:

    • %y 两位数的年份表示(00-99)
    • %Y 四位数的年份表示(000-9999)
    • %m 月份(01-12)
    • %d 月内中的一天(0-31)
    • %H 24小时制小时数(0-23)
    • %I 12小时制小时数(01-12)
    • %M 分钟数(00=59)
    • %S 秒(00-59)
    • %a 本地简化星期名称
    • %A 本地完整星期名称
    • %b 本地简化的月份名称
    • %B 本地完整的月份名称
    • %c 本地相应的日期表示和时间表示
    • %j 年内的一天(001-366)
    • %p 本地A.M.或P.M.的等价符
    • %U 一年中的星期数(00-53)星期天为星期的开始
    • %w 星期(0-6),星期天为星期的开始
    • %W 一年中的星期数(00-53)星期一为星期的开始
    • %x 本地相应的日期表示
    • %X 本地相应的时间表示
    • %Z 当前时区的名称
    • %% 百分号 % 号本身

    图片显示如下:

    030-02
  4. time 模块内置方法

    序号 方法 描述
    1 time.altzone 返回格林威治西部的夏令时地区的偏移秒数。如果该地区在格林威治东部会返回负值(如西欧,包括英国)。对夏令时启用地区才能使用。
    2 time.asctime([tupletime]) 接受时间元组并返回一个可读的形式为"Tue Dec 11 18:07:14 2008"(2008年12月11日 周二18时07分14秒)的24个字符的字符串。
    3 [time.clock() 用以浮点数计算的秒数返回当前的CPU时间。用来衡量不同程序的耗时,比time.time()更有用。由于该方法依赖操作系统,在 3.8 版本中被移除,使用下列两个函数替代。time.perf_counter() # 返回系统运行时间 time.process_time() # 返回进程运行时间
    4 time.ctime([secs]) 作用相当于asctime(localtime(secs)),未给参数相当于asctime()
    5 time.gmtime([secs]) 接收时间辍(1970纪元后经过的浮点秒数)并返回格林威治天文时间下的时间元组t。注:t.tm_isdst始终为0
    6 time.localtime([secs]) 接收时间辍(1970纪元后经过的浮点秒数)并返回当地时间下的时间元组t(t.tm_isdst可取0或1,取决于当地当时是不是夏令时)。
    7 time.mktime(tupletime) 接受时间元组并返回时间辍(1970纪元后经过的浮点秒数)。
    8 time.sleep(secs) 推迟调用线程的运行,secs指秒数。
    9 time.strftime(fmt[,tupletime]) 接收以时间元组,并返回以可读字符串表示的当地时间,格式由fmt决定。
    10 time.strptime(str,fmt='%a %b %d %H:%M:%S %Y') 根据 fmt 的格式把一个时间字符串解析为时间元组。
    11 time.time( ) 返回当前时间的时间戳(1970纪元后经过的浮点秒数)。
    12 time.tzset() 根据环境变量TZ重新初始化时间相关设置。
    13 time.perf_counter() 返回计时器的精准时间(系统的运行时间),包含整个系统的睡眠时间。由于返回值的基准点是未定义的,所以,只有连续调用的结果之间的差才是有效的。
    14 time.process_time() 返回当前进程执行 CPU 的时间总和,不包含睡眠时间。由于返回值的基准点是未定义的,所以,只有连续调用的结果之间的差才是有效的。
  5. 重要属性

    序号 属性 描述
    1 time.timezone 属性time.timezone是当地时区(未启动夏令时)距离格林威治的偏移秒数(>0,美洲;<=0大部分欧洲,亚洲,非洲)。
    2 time.tzname 属性time.tzname包含一对根据情况的不同而不同的字符串,分别是带夏令时的本地时区名称,和不带的。

datetime

datetime 模块用于是date和time模块的合集,datetime 模块定义了5个类,分别是:

  1. datetime.date:表示日期的类

  2. datetime.datetime:表示日期时间的类

  3. datetime.time:表示时间的类

  4. datetime.timedelta:表示时间间隔,即两个时间点的间隔

  5. datetime.tzinfo:时区的相关信息

上一篇下一篇

猜你喜欢

热点阅读