Python:时间模块:time和datetime

1. time模块介绍

使用time模块,首先需要导入它:

import time

time模块提供各种操作时间的函数,一般有两种表示时间的方式:

  • 时间戳的方式(相对于1970.1.1 00:00:00以秒计算的偏移量),时间戳是惟一的
  • 以数组的形式表示即(struct_time),共有九个元素分别表示。同一个时间戳的struct_time会因为时区不同而不同:
    year (four digits, e.g. 1998)
    month (1-12)
    day (1-31)
    hours (0-23)
    minutes (0-59)
    seconds (0-59)
    weekday (0-6, Monday is 0)
    Julian day (day in the year, 1-366)
    DST (Daylight Savings Time) flag (-1, 0 or 1) 是否是夏令时
    If the DST flag is 0, the time is given in the regular time zone;
    if it is 1, the time is given in the DST time zone;
    if it is -1, mktime() should guess based on the date and time.

2. time模块函数介绍

ctime(…)

将一个时间戳(默认为当前时间)转换成一个时间字符串
例如:

>>>import time
>>>time.ctime()
'Sat Jul 23 10:42:48 2016'

asctime()

将一个struct_time(默认为当时时间),转换成字符串
例:

>>> time.asctime()
'Sat Jul 23 09:34:58 2016'

clock()

该函数有两个功能:在第一次调用的时候,返回的是程序运行的实际时间;从第二次之后的调用,返回的是自第一次调用后,到这次调用的时间间隔

sleep(…)

sleep(seconds):可以通过调用time.sleep来挂起当前的进程。time.sleep接收一个浮点型参数,表示进程挂起的时间

gmtime(…)

gmtime([seconds]) -> (tm_year, tm_mon, tm_day, tm_hour, tm_min,tm_sec, tm_wday, tm_yday, tm_isdst)

将一个时间戳转换成一个UTC时区(0时区)的struct_time,如果seconds参数未输入,则以当前时间为转换标准

>>> t=time.time()
>>> time.gmtime(t)
time.struct_time(tm_year=2016, tm_mon=7, tm_mday=23, tm_hour=2, tm_min=53, tm_sec=35, tm_wday=5, tm_yday=205, tm_isdst=0)

localtime(…)

time.localtime与time.gmtime非常类似,也返回一个struct_time对象,可以把它看作是gmtime()的本地化版本。

mktime(…)

mktime(tuple) -> floating point number

time.mktime执行与gmtime(), localtime()相反的操作,它接收struct_time对象作为参数,返回用秒数来表示时间的浮点数。

>>> t=time.localtime()
>>> t
(2011, 2, 12, 16, 15, 42, 5, 43, 0)
>>> time.mktime(t)
1297498542.0

strftime(…)

strftime(format[, tuple]) -> string
将指定的struct_time(默认为当前时间),根据指定的格式化字符串输出
python中时间日期格式化符号:

%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 当前时区的名称
%% %号本身
>>> print(time.strftime('%Y-%m-%d %H:%M:%S'))
2016-07-23 14:50:12
>>> print(time.strftime('Weekday: %w; Day of the yesr: %j'))
Weekday: 6; Day of the yesr: 205

strptime(…)

strptime(string, format) -> struct_time

将时间字符串根据指定的格式化符转换成数组形式的时间
例如:

2009-03-20 11:45:39  对应的格式化字符串为:%Y-%m-%d %H:%M:%S
Sat Mar 28 22:24:24 2009 对应的格式化字符串为:%a %b %d %H:%M:%S %Y

>>> print(time.strptime('2009-06-23 15:30:53', '%Y-%m-%d %H:%M:%S') )
time.struct_time(tm_year=2009, tm_mon=6, tm_mday=23, tm_hour=15, tm_min=30, tm_sec=53, tm_wday=1, tm_yday=174, tm_isdst=-1)

time(…)

time() -> floating point number

返回当前时间的时间戳

>>> t=time.time()
>>> t
1297498791.3916249

3. datetime模块

datetime模块定义了两个常量:datetime.MINYEARdatetime.MAXYEAR,分别表示datetime所能表示的最 小、最大年份。其中,MINYEAR = 1,MAXYEAR = 9999。

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

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

date类

date类表示一个日期。日期由年、月、日组成。date类的构造函数如下:
class datetime.date(year, month, day):参数的意义就不多作解释了,只是有几点要注意一下:

  • year的范围是[MINYEAR, MAXYEAR],即[1, 9999];
  • month的范围是[1, 12]。(月份是从1开始的,不是从0开始的~_~);
  • day的最大值根据给定的year, month参数来决定。例如闰年2月份有29天;

date类定义了一些常用的类方法与类属性,方便我们操作:

    date.maxdate.mindate对象所能表示的最大、最小日期;
    date.resolution:date对象表示日期的最小单位。这里是天。
    date.today():返回一个表示当前本地日期的date对象;
    date.fromtimestamp(timestamp):根据给定的时间戮,返回一个date对象;
    datetime.fromordinal(ordinal):将Gregorian日历时间转换为date对象;(Gregorian Calendar :一种日历表示方法,类似于我国的农历,西方国家使用比较多,此处不详细展开讨论。)

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

    date.yeardate.monthdate.day:年、月、日;
    date.replace(year, month, day):生成一个新的日期对象,用参数指定的年,月,日代替原有对象中的属性。(原有对象仍保持不变)
    date.timetuple():返回日期对应的time.struct_time对象;
    date.toordinal():返回日期对应的Gregorian Calendar日期;
    date.weekday():返回weekday,如果是星期一,返回0;如果是星期2,返回1,以此类推;
    data.isoweekday():返回weekday,如果是星期一,返回1;如果是星期2,返回2,以此类推;
    date.isocalendar():返回格式如(yearmonthday)的元组;
    date.isoformat():返回格式如'YYYY-MM-DD’的字符串;
    date.strftime(fmt):自定义格式化字符串。在下面详细讲解。

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

    date2 = date1 + timedelta  # 日期加上一个间隔,返回一个新的日期对象(timedelta将在下面介绍,表示时间间隔)
    date2 = date1 - timedelta   # 日期隔去间隔,返回一个新的日期对象
    timedelta = date1 - date2   # 两个日期相减,返回一个时间间隔对象
    date1 < date2  # 两个日期进行比较

注: 对日期进行操作时,要防止日期超出它所能表示的范围。
使用例子:

    now = date.today()  
    tomorrow = now.replace(day = 7 )  
    delta = tomorrow - now  
    print'now:' , now,  ' tomorrow:' , tomorrow)
    print'timedelta:' , delta)
    print (now + delta)
    print (tomorrow > now)

    # # ---- 结果 ----   
    # now: 2010-04-06  tomorrow: 2010-04-07   
    # timedelta: 1 day, 0:00:00   
    # 2010-04-07   
    # True 

time类

time类表示时间,由时、分、秒以及微秒组成。time类的构造函数如下:

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

各参数的意义不作解释,这里留意一下参数tzinfo,它表示时区信息。注意一下各参数的取值范围:hour的范围为[0, 24),minute的范围为[0, 60),second的范围为[0, 60),microsecond的范围为[0, 1000000)。

time类定义的类属性:

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

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

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

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

datetime类

datetime是date与time的结合体,包括date与time的所有信息。它的构造函数如下:

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

各参数的含义与date、time的构造函数中的一样,要注意参数值的范

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

    datetime.min、datetime.max:datetime所能表示的最小值与最大值;
    datetime.resolution:datetime最小单位;
    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对象;

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

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

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

datetime、date、time都提供了strftime()方法,该方法接收一个格式字符串,输出日期时间的字符串表示。下表是从python手册中拉过来的,我对些进行了简单的翻译(翻译的有点噢口~~)。

格式字符 意义

%a 星期的简写。如 星期三为Web
%A 星期的全写。如 星期三为Wednesday
%b 月份的简写。如4月份为Apr
%B月份的全写。如4月份为April
%c: 日期时间的字符串表示。(如: 04/07/10 10:43:39)
%d: 日在这个月中的天数(是这个月的第几天)
%f: 微秒(范围[0,999999])
%H: 小时(24小时制,[0, 23])
%I: 小时(12小时制,[0, 11])
%j: 日在年中的天数 [001,366](是当年的第几天)
%m: 月份([01,12])
%M: 分钟([00,59])
%p: AM或者PM
%S: 秒(范围为[00,61],为什么不是[00, 59],参考python手册~_~)
%U: 周在当年的周数当年的第几周),星期天作为周的第一天
%w: 今天在这周的天数,范围为[0, 6],6表示星期天
%W: 周在当年的周数(是当年的第几周),星期一作为周的第一天
%x: 日期字符串(如:04/07/10)
%X: 时间字符串(如:10:43:39)
%y: 2个数字表示的年份
%Y: 4个数字表示的年份
%z: 与utc时间的间隔 (如果是本地时间,返回空字符串)
%Z: 时区名称(如果是本地时间,返回空字符串)
%%: %% => %

例子:

    dt = datetime.now()  
    print   '(%Y-%m-%d %H:%M:%S %f): ' , dt.strftime( '%Y-%m-%d %H:%M:%S %f' )  
    print   '(%Y-%m-%d %H:%M:%S %p): ' , dt.strftime( '%y-%m-%d %I:%M:%S %p' )  
    print   '%%a: %s '  % dt.strftime( '%a' )  
    print   '%%A: %s '  % dt.strftime( '%A' )  
    print   '%%b: %s '  % dt.strftime( '%b' )  
    print   '%%B: %s '  % dt.strftime( '%B' )  
    print   '日期时间%%c: %s '  % dt.strftime( '%c' )  
    print   '日期%%x:%s '  % dt.strftime( '%x' )  
    print   '时间%%X:%s '  % dt.strftime( '%X' )  
    print   '今天是这周的第%s天 '  % dt.strftime( '%w' )  
    print   '今天是今年的第%s天 '  % dt.strftime( '%j' )  
    print   '今周是今年的第%s周 '  % dt.strftime( '%U' )  

    # # ---- 结果 ----   
    # (%Y-%m-%d %H:%M:%S %f):  2010-04-07 10:52:18 937000   
    # (%Y-%m-%d %H:%M:%S %p):  10-04-07 10:52:18 AM   
    # %a: Wed    
    # %A: Wednesday    
    # %b: Apr    
    # %B: April    
    # 日期时间%c: 04/07/10 10:52:18    
    # 日期%x04/07/10    
    # 时间%X10:52:18    
    # 今天是这周的第3天    
    # 今天是今年的第097天    
    # 今周是今年的第14
  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值