datetime模块

datetime模块

  1. datetime模块介绍

    datetime模块提供了一些处理日期和时间的标准库,datatime模块重新封装了time模块,提供更多接口,提供的类有date,time,datetime,timedelta,tzinfo,常用的有datetime,timedelta,timezone。

  2. datetime模块提供的类
    1. data类

      datetime.date(year, month, day)
      
      # 静态方法和字段
      date.max、date.min # date对象所能表示的最大、最小日期;
      date.resolution # date对象表示日期的最小单位。这里是天。
      date.today() # 返回一个表示当前本地日期的date对象;
      date.fromtimestamp(timestamp) # 根据给定的时间戮,返回一个date对象;
      
      # 方法和属性
      dt = date(2011,06,03) # date对象
      dt.year、dt.month、dt.day # 年、月、日;
      dt.replace(year, month, day) # 生成一个新的日期对象,用参数指定的年,月,日代替原有对象中的属性。(原有对象仍保持不变)
      dt.timetuple() # 返回日期对应的time.struct_time对象;
      dt.weekday() # 返回weekday,如果是星期一,返回0;如果是星期2,返回1,以此类推;
      dt.isoweekday() # 返回weekday,如果是星期一,返回1;如果是星期2,返回2,以此类推;
      dt.isocalendar() # 返回格式如(year,month,day)的元组;
      dt.isoformat() # 返回格式如'YYYY-MM-DD’的字符串;
      dt.strftime(fmt) # 和time模块format相同。
      
    2. time类

      datetime.time(hour[ , minute[ , second[ , microsecond[ , tzinfo] ] ] ] ) 
      
      # 静态方法和字段 
      # 其中,time.min = time(0, 0, 0, 0), time.max = time(23, 59, 59, 999999);
      time.min、time.max:time类所能表示的最小、最大时间。
      time.resolution:时间的最小单位,这里是1微秒;
      
      # 方法和属性
      dt = datetime.time(10,23,15) #time对象
      dt.hour、dt.minute、dt.second、dt.microsecond # 时、分、秒、微秒;
      dt.tzinfo # 时区信息;
      dt.replace([ hour[ , minute[ , second[ , microsecond[ , tzinfo] ] ] ] ] ) # 创建一个新的时间对象,用参数指定的时、分、秒、微秒代替原有对象中的属性(原有对象仍保持不变);
      dt.isoformat() # 返回型如"HH:MM:SS"格式的字符串表示;
      dt.strftime(fmt) #同time模块中的format;
      
    3. datetime类

      datetime # 相当于date和time结合起来。
      datetime.datetime (year, month, day[ , hour[ , minute[ , second[ , microsecond[ , tzinfo] ] ] ] ] )
      
      # 静态方法和字段 
      datetime.today() # 返回一个表示当前本地时间的datetime对象;
      datetime.now([tz]) # 返回一个表示当前本地时间的datetime对象,如果提供了参数tz,则获取tz参数所指时区的本地时间;
      datetime.utcnow() # 返回一个当前utc时间的datetime对象;#格林威治时间
      datetime.fromtimestamp(timestamp[, tz]) # 根据时间戮创建一个datetime对象,参数tz指定时区信息;
      datetime.utcfromtimestamp(timestamp) # 根据时间戮创建一个datetime对象;
      datetime.combine(date, time) # 根据date和time,创建一个datetime对象;
      datetime.strptime(date_string, format) # 将格式字符串转换为datetime对象;
      
      # 方法和属性
      dt = datetime.now() #datetime对象
      dt.year、month、day、hour、minute、second、microsecond、tzinfo
      dt.date() # 获取date对象;
      dt.time() # 获取time对象;
      
      # 创建一个新的对象,用参数指定的‘年月日时分秒微秒’代替原有对象中的属性(原有对象仍保持不变);
      dt. replace ([ year[ , month[ , day[ , hour[ , minute[ , second[ , microsecond[ , tzinfo] ] ] ] ] ] ] ])
      
      # 返回日期对应的time.struct_time对象;返回一个类型为time.struct_time的数组,但有关时间的部分元素值为0
      dt. timetuple ()  
      """
      dt = datetime.date(2017,3,22) 
      dt.timetuple()
      # time.struct_time(tm_year=2017, tm_mon=3, tm_mday=22, tm_hour=0, tm_min=0, tm_sec=0, tm_wday=2, tm_yday=81, tm_isdst=-1)
      """
      # 返回UTC时区对应的time.struct_time对象;返回一个类型为time.struct_time的数组,但有关时间的部分元素值为0
      dt. utctimetuple ()
      
      # 返回日期对应的 Gregorian Calendar 日期
      dt. toordinal ()
      
      # 返回weekday,如果是星期一,返回0;如果是星期2,返回1,以此类推;
      dt. weekday ()
      
      # 返回一个包含三个值的元组,三个值依次为:year年份,week number周数,weekday星期数(周一为1…周日为7)
      dt. isocalendar ()
      
      # 返回型如"HH:MM:SS"格式的字符串表示;
      dt. isoformat ([ sep] )
      
      # 返回一个日期时间的C格式字符串,等效于time.ctime(time.mktime(dt.timetuple()));
      dt. ctime () 
      
      # 将格式字符串转换为datetime对象;
      dt. strftime (format) 
      
    4. timedelta类,时间加减

      使用timedelta可以很方便的在日期上做天days,小时hour,分钟,秒,毫秒,微妙的时间计算,如果要计算月份则需要另外的办法。

      from  datetime import *
      
      dt = datetime.now()
      #日期减一天
      dt1 = dt + timedelta(days=-1) # 昨天
      dt2 = dt - timedelta(days=1) # 昨天
      dt3 = dt + timedelta(days=1) # 明天
      delta_obj = dt3-dt
      print(type(delta_obj),delta_obj) #<type 'datetime.timedelta'> 1 day, 0:00:00
      print(delta_obj.days ,delta_obj.total_seconds())
      
    5. tzinfo时区类,tzinfo是关于时区信息的类,tzinfo是一个抽象类,所以不能直接被实例化

      from datetime import datetime, tzinfo,timedelta
      
      class UTC(tzinfo):
          """UTC"""
          def __init__(self,offset = 0):
              self._offset = offset
      
          def utcoffset(self, dt):
              return timedelta(hours=self._offset)
      
          def tzname(self, dt):
              return "UTC +%s" % self._offset
      
          def dst(self, dt):
              return timedelta(hours=self._offset)
      
      #北京时间
      beijing = datetime(2011,11,11,0,0,0,tzinfo = UTC(8))
      print("beijing time:",beijing)
      #曼谷时间
      bangkok = datetime(2011,11,11,0,0,0,tzinfo = UTC(7))
      print(bangkok time",bangkok)
            
      #北京时间转成曼谷时间
      print("beijing-time to bangkok-time:",beijing.astimezone(UTC(7)))
      
      #计算时间差时也会考虑时区的问题
      timespan = beijing - bangkok
      print("时差:",timespan)
      
      # beijing time: 2011-11-11 00:00:00+08:00
      # bangkok time 2011-11-11 00:00:00+07:00
      # beijing-time to bangkok-time: 2011-11-10 23:00:00+07:00
      # 时差: -1 day, 23:00:00
      
  3. format time结构化表示
    %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	时区的名字(如果不存在为空字符)
    %%	‘%’字符
    
  4. 时间三种表达形式
    # 自定义的格式型字符串时间:format_time (自定义的、非自定义)  
    # 元组型(格式化)时间:struct_time
    # 时间戳:time_stamp
    
    # 三种表达形式转换(datetime模块)(方法很多种)
    # 时间戳-->格式化-->字符型
    # 时间戳
    tb = 1456787645.34 
    # 时间戳转化为格式化的时间
    st = datetime.datetime.fromtimestamp(tb) 
    # 格式化时间转化字符型
    str_time = datetime.datetime.strftime(st, "%Y-%m-%d %H:%M:%S") 
    
    # 字符型 -->格式化 --> 时间戳
    # 字符型
    str_time = '2019-10-21 18:26:45'
    # 字符型转格式化
    ft = datetime.datetime.strptime(str_time, '%Y-%m-%d %H:%M:%S')
    # 格式化转时间戳
    time_stamp = datetime.datetime.timestamp(st)
    
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值