# datetime

# datetime模块

datetime 比 time 高级了不少,可以理解为 datetime 基于 time 进行了封装,提供了更多实用的函数。

c7936ae269c3ea84347afa25690d2375.png

datetime模块定义了下面这几个类:

  • date:表示日期的类。常用的属性有year, month, day
  • time:表示时间的类。常用的属性有hour, minute, second, microsecond
  • datetime:表示日期时间
  • timedelta:表示时间间隔,即两个时间点之间的长度
  • timezone:与时区有关的相关信息

** 注意上面这些类型的对象都是不可变(immutable)的。**

# date类

date类定义了一些常用的类方法与类属性:

  • max、min:date对象所能表示的最大、最小日期
  • resolution:date对象表示日期的最小单位。这里是天
  • today():返回一个表示当前本地日期的date对象
  • fromtimestamp(timestamp):根据给定的时间戮,返回一个date对象
  • fromordinal(ordinal):将Gregorian日历时间转换为date对象(特殊历法用不上)
from datetime import date
import time
print('date.max:', date.max)
print('date.min:', date.min)
print('date.resolution:', date.resolution)
print('date.today():', date.today())
print('date.fromtimestamp():', date.fromtimestamp(time.time()))

执行结果:

date.max: 9999-12-31
date.min: 0001-01-01
date.resolution: 1 day, 0:00:00
date.today(): 2016-09-12
date.fromtimestamp(): 2016-09-12

date提供的实例方法和属性:

  • .year:返回年
  • .month:返回月
  • .day:返回日
  • .replace(year, month, day...):生成一个新的日期对象,用参数指定的年,月,日等属性代替原有对象中的属性。(原有对象仍保持不变)
  • .weekday():返回weekday,如果是星期一,返回0;如果是星期2,返回1,以此类推
  • .isoweekday():返回weekday,如果是星期一,返回1;如果是星期2,返回2,以此类推
  • .isocalendar():返回格式如(year, wk num, wk day)
  • .isoformat():返回格式如’YYYY-MM-DD’的字符串
  • .strftime(fmt):自定义格式化字符串。与time模块中的strftime类似。
  • .toordinal():返回日期对应的Gregorian Calendar日期
from datetime import date
today = date.today()
print('today:', today)
print('.year:', today.year)
print('.month:', today.month)
print('.replace():', today.replace(year=2017) )
print('.weekday():', today.weekday())
print('.isoweekday():', today.isoweekday())
print('.isocalendar():', today.isocalendar())
print('.isoformat():', today.isoformat())
print('.strftime():', today.strftime('%Y-%m-%d') )
print('.toordinal():', today.toordinal())

执行结果:

today: 2016-09-12
.year: 2016
.month: 9
.replace(): 2017-09-12
.weekday(): 0
.isoweekday(): 1
.isocalendar(): (2016, 37, 1)
.isoformat(): 2016-09-12
.strftime(): 2016-09-12
.toordinal(): 736219

date还对某些操作进行了重载,它允许我们对日期进行如下一些操作:

  • date2 = date1 + timedelta # 日期加上一个间隔,返回一个新的日期对象
  • date2 = date1 – timedelta # 日期减去一个间隔,返回一个新的日期对象
  • timedelta = date1 – date2 # 两个日期相减,返回一个时间间隔对象
  • date1 < date2 # 两个日期进行比较

# time类

time类的构造函数如下:(其中参数tzinfo,它表示时区信息。)

 class datetime.time(hour[, minute[, second[, microsecond[, tzinfo]]]])

time类定义的类属性:

  • min、max:time类所能表示的最小、最大时间。其中,time.min = time(0, 0, 0, 0), time.max = time(23, 59, 59, 999999)
  • resolution:时间的最小单位,这里是1微秒

time类提供的实例方法和属性:

  • .hour、.minute、.second、.microsecond:时、分、秒、微秒
  • .tzinfo:时区信息
  • .replace([hour[, minute[, second[, microsecond[, tzinfo]]]]]):创建一个新的时间对象,用参数指定的时、分、秒、微秒代替原有对象中的属性(原有对象仍保持不变);
  • .isoformat():返回型如”HH:MM:SS”格式的字符串表示;
  • .strftime(fmt):返回自定义格式化字符串。

像date一样,也可以对两个time对象进行比较,或者相减返回一个时间间隔对象。

# datetime类

datetime是date与time的结合体,包括date与time的所有信息。其各参数的含义与date、time的构造函数中的一样。

datetime.datetime(year, month, day[, hour[, minute[, second[, microsecond[, tzinfo]]]]])

datetime类定义的类属性与方法:

  • min、max:datetime所能表示的最小值与最大值;
  • resolution:datetime最小单位;
  • today():返回一个表示当前本地时间的datetime对象;
  • now([tz]):返回一个表示当前本地时间的datetime对象,如果提供了参数tz,则获取tz参数所指时区的本地时间;
  • utcnow():返回一个当前utc时间的datetime对象;
  • fromtimestamp(timestamp[, tz]):根据时间戮创建一个datetime对象,参数tz指定时区信息;
  • utcfromtimestamp(timestamp):根据时间戮创建一个datetime对象;
  • combine(date, time):根据date和time,创建一个datetime对象;
  • strptime(date_string, format):将格式字符串转换为datetime对象;
from datetime import datetime
import time
print('datetime.max:', datetime.max)
print('datetime.min:', datetime.min)
print('datetime.resolution:', datetime.resolution)
print('today():', datetime.today())
print('now():', datetime.now())
print('utcnow():', datetime.utcnow())
print('fromtimestamp(tmstmp):', datetime.fromtimestamp(time.time()))
print('utcfromtimestamp(tmstmp):', datetime.utcfromtimestamp(time.time()))

运行结果:

datetime.max: 9999-12-31 23:59:59.999999
datetime.min: 0001-01-01 00:00:00
datetime.resolution: 0:00:00.000001
today(): 2016-09-12 19:57:00.761000
now(): 2016-09-12 19:57:00.761000
utcnow(): 2016-09-12 11:57:00.761000
fromtimestamp(tmstmp): 2016-09-12 19:57:00.761000
utcfromtimestamp(tmstmp): 2016-09-12 11:57:00.761000

datetime类提供的实例方法与属性(很多属性或方法在date和time中已经出现过,在此有类似的意义,这里只罗列这些方法名,具体含义不再逐个展开介绍,可以参考上文对date与time类的讲解。):

year、month、day、hour、minute、second、microsecond、tzinfo:

  • date():获取date对象;
  • time():获取time对象;
  • replace([year[, month[, day[, hour[, minute[, second[, microsecond[, tzinfo]]]]]]]]):
  • timetuple()
  • utctimetuple()
  • toordinal()
  • weekday()
  • isocalendar()
  • isoformat([sep])
  • ctime():返回一个日期时间的C格式字符串,等效于ctime(time.mktime(dt.timetuple()));
  • strftime(format)

像date一样,也可以对两个datetime对象进行比较,或者相减返回一个时间间隔对象,或者日期时间加上一个间隔返回一个新的日期时间对象。

# timedelta类

通过timedelta函数返回一个timedelta对象,也就是一个表示时间间隔的对象。函数参数情况如下所示:

 class datetime.timedelta([days[, seconds[, microseconds[, milliseconds[, minutes[, hours[, weeks]]]]]]])

其没有必填参数,简单控制的话第一个整数就是多少天的间隔的意思:

datetime.timedelta(10)

两个时间间隔对象可以彼此之间相加或相减,返回的仍是一个时间间隔对象。而更方便的是一个datetime对象如果减去一个时间间隔对象,那么返回的对应减去之后的datetime对象,然后两个datetime对象如果相减返回的是一个时间间隔对象。这很是方便。

# tzinfo类

tzinfo是一个抽象类,不能被直接实例化。需要派生子类,提供相应的标准方法。datetime模块并不提供tzinfo的任何子类。最简单的方式是使用pytz模块。