Par rapport au module time, l'interface du module datetime est plus intuitive et plus facile à appeler. Aujourd'hui, parlons du module datetime.
Le module datetime définit deux constantes : datetime.MINYEAR et datetime.MAXYEAR, qui représentent respectivement l'année minimale et maximale que datetime peut représenter. Parmi eux, MINYEAR = 1, MAXYEAR = 9999. (Pour les joueurs occasionnels, cette plage est suffisante~~)
Le module datetime définit les classes suivantes :
•datetime.date : une classe représentant la date. Les attributs couramment utilisés incluent l'année, le mois et le jour ;
•datetime.time : une classe représentant l'heure. Les attributs couramment utilisés incluent l'heure, la minute, la seconde, la microseconde ;
•datetime.datetime : représente la date et l'heure.
•datetime.timedelta : représente l'intervalle de temps, c'est-à-dire la durée entre deux points temporels.
•datetime.tzinfo : informations associées liées aux fuseaux horaires. (Cette classe ne sera pas entièrement discutée en détail ici. Les enfants intéressés peuvent se référer au manuel de python)
Remarque : les types d'objets ci-dessus sont tous immuables.
Ce qui suit décrit comment utiliser ces classes en détail.
classe de date
classe de date représente une date. La date comprend l'année, le mois et le jour (tout le monde sur terre le sait ~~). Le constructeur de la classe date est le suivant :
class datetime.date(année, mois, jour) : La signification des paramètres ne sera pas beaucoup expliquée, mais il y a quelques points auxquels il faut faire attention :
• La plage de l'année est [MINYEAR, MAXYEAR], c'est-à-dire [1, 9999] ; la plage de
·mois est [1, 12]. (Le mois commence à 1, pas à 0~_~) ;
•La valeur maximale du jour est déterminée en fonction des paramètres de l'année et du mois donnés. Par exemple, février dans une année bissextile compte 29 jours ;
La classe date définit certaines méthodes de classe et attributs de classe couramment utilisés pour faciliter nos opérations :
•date.max, date.min : la valeur maximale que l'objet date peut représenter, la date minimale ;
•date.resolution : L'objet date représente l'unité minimale de date. C'est le paradis.
•date.today() : renvoie un objet date représentant la date locale actuelle ;
•date.fromtimestamp(timestamp) : renvoie un objet date basé sur l'horodatage donné
•datetime.fromordinal ( ordinal) : Convertissez l'heure du calendrier grégorien en un objet date ; (Calendrier grégorien : une méthode de représentation du calendrier, similaire au calendrier lunaire de notre pays, qui est plus couramment utilisée dans les pays occidentaux et ne sera pas discutée en détail ici.)
Exemple d'utilisation :
from datetime import * import time print 'date.max:', date.max print 'date.min:', date.min print 'date.today():', date.today() print 'date.fromtimestamp():', date.fromtimestamp(time.time()) # # ---- 结果 ---- # date.max: 9999-12-31 # date.min: 0001-01-01 # date.today(): 2010-04-06 # date.fromtimestamp(): 2010-04-06
Méthodes et attributs d'instance fournis par date :
•date.year, date.month, date.day : année, mois, jour <🎜 ; >•date.replace(year,month, day) : génère un nouvel objet date, en remplaçant les attributs de l'objet d'origine par l'année, le mois et le jour spécifiés par les paramètres. (L'objet d'origine reste inchangé)
•date.timetuple() : Renvoie l'objet time.struct_time correspondant à la date
•date.toordinal() : Renvoie la date du calendrier grégorien correspondant à la date ; >• date.weekday() : renvoie le jour de la semaine, si c'est lundi, renvoie 0 ; si c'est lundi, renvoie 1, et ainsi de suite ;
•data.isoweekday() : renvoie le jour de la semaine, si c'est lundi, renvoie 1; Si c'est le 2 de la semaine, renvoie 2, et ainsi de suite ;
•date.isocalendar() : Renvoie un tuple avec un format tel que
•date) ; isoformat() : renvoie un tuple avec un format tel que la chaîne ' AAAA-MM-JJ' ;
•date.strftime(fmt) : chaîne de format personnalisé. Expliquez en détail ci-dessous.
Exemple d'utilisation :
now = date(2010, 04, 06) tomorrow = now.replace(day = 07) print 'now:', now, ', tomorrow:', tomorrow print 'timetuple():', now.timetuple() print 'weekday():', now.weekday() print 'isoweekday():', now.isoweekday() print 'isocalendar():', now.isocalendar() print 'isoformat():', now.isoformat() # # ---- 结果 ---- # now: 2010-04-06 , tomorrow: 2010-04-07 # timetuple(): (2010, 4, 6, 0, 0, 0, 1, 96, -1) # weekday(): 1 # isoweekday(): 2 # isocalendar(): (2010, 14, 2) # isoformat(): 2010-04-06
·date2 = date1 timedelta # Ajouter un intervalle à la date et renvoie un nouvel objet date (timedelta sera introduit ci-dessous pour représenter l'intervalle de temps)
•date2 = date1 - timedelta # Ajoutez l'intervalle à la date et renvoie un nouvel objet date
•timedelta = date1 - date2 # Soustrayez deux dates et renvoyez un objet d'intervalle de temps
•date1 < date2 # Comparez deux dates
Remarque : lorsque vous travaillez sur des dates, assurez-vous d'éviter que la date ne dépasse ce qu'elle peut représenter.
Exemple d'utilisation :
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.min、time.max:time类所能表示的最小、最大时间。其中,time.min = time(0, 0, 0, 0), time.max = time(23, 59, 59, 999999);
•time.resolution:时间的最小单位,这里是1微秒;
time类提供的实例方法和属性:
•time.hour、time.minute、time.second、time.microsecond:时、分、秒、微秒;
•time.tzinfo:时区信息;
•time.replace([hour[, minute[, second[, microsecond[, tzinfo]]]]]):创建一个新的时间对象,用参数指定的时、分、秒、微秒代替原有对象中的属性(原有对象仍保持不变);
•time.isoformat():返回型如"HH:MM:SS"格式的字符串表示;
•time.strftime(fmt):返回自定义格式化字符串。在下面详细介绍;
使用例子:
from datetime import * tm = time(23, 46, 10) print 'tm:', tm print 'hour: %d, minute: %d, second: %d, microsecond: %d' / % (tm.hour, tm.minute, tm.second, tm.microsecond) tm1 = tm.replace(hour = 20) print 'tm1:', tm1 print 'isoformat():', tm.isoformat() # # ---- 结果 ---- # tm: 23:46:10 # hour: 23, minute: 46, second: 10, microsecond: 0 # tm1: 20:46:10 # isoformat(): 23:46:10
像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对象;
使用例子:
from datetime import * 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(): 2010-04-07 09:48:16.234000 # now(): 2010-04-07 09:48:16.234000 # utcnow(): 2010-04-07 01:48:16.234000 # 中国位于+8时间,与本地时间相差8 # fromtimestamp(tmstmp): 2010-04-07 09:48:16.234000 # utcfromtimestamp(tmstmp): 2010-04-07 01:48:16.234000
datetime类提供的实例方法与属性(很多属性或方法在date和time中已经出现过,在此有类似的意义,这里只罗列这些方法名,具体含义不再逐个展开介绍,可以参考上文对date与time类的讲解。):
•datetime.year、month、day、hour、minute、second、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 # 日期%x:04/07/10 # 时间%X:10:52:18 # 今天是这周的第3天 # 今天是今年的第097天 # 今周是今年的第14周
这些就是datetime模块的基本内容,总算写完了~~oh yeah~~
更多Python模块学习 datetime介绍相关文章请关注PHP中文网!