datetime模块 导入模块 模块中的类
datatime模块重新封装了time模块,提供更多接口,提供的类有:date,time,datetime,timedelta,tzinfo
import datetime
模块中的类
date类
datetime.date(year, month, day)
import datetime import time # 静态方法和字段 print(datetime.date.max) # 9999-12-31,date对象所能表示的最大日期 print(datetime.date.min) # 0001-01-01,date对象所能表示的最小日期 print(datetime.date.resolution) # 1 day, 0:00:00,date对象表示日期的最小单位。这里是天。 print(datetime.date.today()) # 2018-08-12,返回一个表示当前本地日期的date对象 print(datetime.date.fromtimestamp(time.time())) # 2018-08-12,根据给定的时间戮,返回一个date对象 # 对象方法和属性 d1 = datetime.date(2018, 8, 12) #date对象 print(d1.year) # 2018,年 print(d1.month) # 8,月 print(d1.day) # 12,日 print(d1.replace(2018, 8, 8).day) # 8,生成一个新的日期对象,用参数指定的年,月,日代替原有对象中的属性。(原有对象仍保持不变) print(d1.timetuple()) # time.struct_time(tm_year=2018, tm_mon=8, tm_mday=12, tm_hour=0, tm_min=0, tm_sec=0, tm_wday=6, tm_yday=224, tm_isdst=-1),返回日期对应的时间元组; print(d1.weekday()) # 6,返回weekday,如果是星期一,返回0;如果是星期2,返回1,以此类推; print(d1.isoweekday()) # 7 ,返回weekday,如果是星期一,返回1;如果是星期2,返回2,以此类推; print(d1.isoformat()) # 2018-08-12 ,返回格式如'YYYY-MM-DD’的字符串; print(d1.strftime("%Y/%m/%d")) # 2018/08/12,和time模块format相同。
time类
datetime.time(hour[ , minute[ , second[ , microsecond[ , tzinfo] ] ] ] )
import datetime # 静态方法和字段 print(datetime.time.min) # 00:00:00,time类所能表示的最小的时间 print(datetime.time.max) # 23:59:59.999999,time类所能表示的最大的时间 print(datetime.time.resolution) # 0:00:00.000001,时间最小单位,这里是1微秒 # 方法和属性 t1 = datetime.time(10, 23, 15) print(t1.hour) # 10,时 print(t1.minute) # 23,分 print(t1.second) # 15,秒 print(t1.microsecond) # 0,微秒 print(t1.tzinfo) # None,时区信息 print(t1.replace(11, 20, 20).hour) # 11,创建一个新的时间对象,用参数指定的时、分、秒、微秒代替原有对象中的属性(原有对象仍保持不变); print(t1.isoformat()) # 10:23:15,返回型如"HH:MM:SS"格式的字符串表示; print(t1.strftime("%H:%M:%S")) # ,同time模块中的format;
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对象;
补充:
如果你的程序要考虑时区,可以使用pytz。datetime模块中有tzinfo相关的东西,但是它是一个抽象类,文档上说: tzinfo is an abstract base clase, meaning that this class should not be instantiated directly. You need to derive a concrete subclass, and (at least) supply implementations of the standard tzinfo methods needed by the datetimemethods you use. The datetime module does not supply any concrete subclasses of tzinfo. 上面是说tzinfo是一个抽象类,不应该被直接实例化。你需要派生子类,提供相应的标准方法。datetime模块并不提供tzinfo的任何子类。 所以你可能会使用pytz这个模块。通过easy_install可以安装。目前它的最新文档在这里。 关于时区使用的几点想法: 1. 如果你的网站可能有来自其它时区的,可能你要考虑这个问题。都是一个地区的话,还要看服务器是否与用户在一个地区,如果不在,也要考虑。 2. 因此,基本上要考虑服务器时区与用户时区。服务器时区可以配置在系统中,全局生效。而用户时区则与用户相关,可以由用户自已进行设置。 3. 在生成相关时间对象时要加入时区的信息,并在输出时进行合适的转换。 而pytz提供了创建某个时区对象的方法,如,中国时区: >>> import pytz >>> pytz.country_timezones('cn') ['Asia/Shanghai', 'Asia/Harbin', 'Asia/Chongqing', 'Asia/Urumqi', 'Asia/Kashgar'] 可以看到,中国的时区可能有:'Asia/Shanghai', 'Asia/Harbin', 'Asia/Chongqing',最后两个不知道是什么。我们可能使用的'Asia/Shanghai'比较多。 因此可以创建一个时区对象: >>> tz = pytz.timezone('Asia/Shanghai') 然后在创建时间对象时进行指定: >>> import datetime >>> datetime.datetime.now(tz) datetime.datetime(2009, 2, 21, 15, 12, 33, 906000, tzinfo=<DstTzInfo 'Asia/Shanghai' CST+8:00:00 STD>) >>> datetime.datetime(2009, 2, 21, 15, 12, 33, tzinfo=tz) datetime.datetime(2009, 2, 21, 15, 12, 33, tzinfo=<DstTzInfo 'Asia/Shanghai' LMT+8:06:00 STD>) >>> datetime.date(2009, 2, 21, tzinfo=tz) Traceback (most recent call last): File "<stdin>", line 1, in <module> TypeError: 'tzinfo' is an invalid keyword argument for this function >>> datetime.time(15, 12, 33, tzinfo=tz) datetime.time(15, 12, 33, tzinfo=<DstTzInfo 'Asia/Shanghai' LMT+8:06:00 STD>) 从上面可以看出now(), datetime(), time()都是可以指定tzinfo信息的,而date是不行的,不知道为什么。所以最好的方法是内部使用datetime对象,需要时进行时区转换,然后再输出。 时区转换: >>> utc = pytz.utc >>> n = datetime.datetime.now(tz) >>> n datetime.datetime(2009, 2, 21, 15, 16, 41, 843000, tzinfo=<DstTzInfo 'Asia/Shanghai' CST+8:00:00 STD>) >>> new = n.astimezone(utc) >>> new datetime.datetime(2009, 2, 21, 7, 16, 41, 843000, tzinfo=<UTC>) >>> utc.normalize(n.astimezone(utc)) datetime.datetime(2009, 2, 21, 7, 16, 41, 843000, tzinfo=<UTC>)
方法和属性
特殊的我会说明,上面说过的就不多写了
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] ] ] ] ] ] ] ]):
dt. timetuple ()
dt. utctimetuple ()
dt. toordinal ()
dt. weekday ()
dt. isocalendar ()
dt. isoformat ([ sep] )
dt. ctime ():返回一个日期时间的C格式字符串,等效于time.ctime(time.mktime(dt.timetuple()));
dt. strftime (format)
timedelta类
使用timedelta可以很方便的在日期上做天days,小时hour,分钟,秒,毫秒,微妙的时间计算,如果要计算月份则需要另外的办法。
#coding:utf-8 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()) # 1 86400.0
tzinfo时区类
#! /usr/bin/python # coding=utf-8 from datetime import datetime, tzinfo, timedelta """ tzinfo是关于时区信息的类 tzinfo是一个抽象类,所以不能直接被实例化 """ 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) # Output================== # 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