Im Vergleich zum Zeitmodul ist die Schnittstelle des Datum/Uhrzeit-Moduls intuitiver und einfacher aufzurufen. Lassen Sie uns heute über das Datetime-Modul sprechen.
Das datetime-Modul definiert zwei Konstanten: datetime.MINYEAR und datetime.MAXYEAR, die jeweils das minimale und maximale Jahr darstellen, das datetime darstellen kann. Darunter ist MINYEAR = 1, MAXYEAR = 9999. (Für Gelegenheitsspieler ist dieser Bereich ausreichend~~)
Das datetime-Modul definiert die folgenden Klassen:
•datetime.date: eine Klasse, die das Datum darstellt. Zu den häufig verwendeten Attributen gehören Jahr, Monat und Tag.
•datetime.time: eine Klasse, die die Zeit darstellt. Zu den häufig verwendeten Attributen gehören Stunde, Minute, Sekunde, Mikrosekunde;
•datetime.datetime: stellt Datum und Uhrzeit dar.
•datetime.timedelta: stellt das Zeitintervall dar, also die Länge zwischen zwei Zeitpunkten.
•datetime.tzinfo: Verwandte Informationen zu Zeitzonen. (Diese Klasse wird hier nicht ausführlich besprochen. Interessierte Kinder können sich auf das Python-Handbuch beziehen.)
Hinweis: Die oben genannten Objekttypen sind alle unveränderlich.
Im Folgenden wird die Verwendung dieser Klassen im Detail beschrieben.
Datumsklasse
Datumsklasse stellt ein Datum dar. Das Datum besteht aus Jahr, Monat und Tag (jeder auf der Erde weiß es~~). Der Konstruktor der Datumsklasse lautet wie folgt:
Klasse datetime.date(Jahr, Monat, Tag): Die Bedeutung der Parameter wird nicht viel erklärt, aber es gibt einige Punkte, auf die man achten sollte:
• Der Bereich für das Jahr ist [MINYEAR, MAXYEAR], also [1, 9999]; der Bereich für
·Monat ist [1, 12]. (Der Monat beginnt bei 1, nicht bei 0~_~);
•Der maximale Wert des Tages wird anhand der angegebenen Jahres- und Monatsparameter bestimmt. Beispielsweise hat der Februar in einem Schaltjahr 29 Tage.
Die Datumsklasse definiert einige häufig verwendete Klassenmethoden und Klassenattribute, um unsere Operationen zu erleichtern:
•Datum.max, Datum.min: der Maximalwert dass das Datumsobjekt ein Mindestdatum darstellen kann;
•date.resolution: Das Datumsobjekt stellt die Mindestdatumseinheit dar. Das ist der Himmel.
•date.today(): Gibt ein Datumsobjekt zurück, das das aktuelle lokale Datum darstellt;
•date.fromtimestamp(timestamp): Gibt ein Datumsobjekt basierend auf dem angegebenen Zeitstempel zurück; Ordinalzahl): Konvertieren Sie die gregorianische Kalenderzeit in ein Datumsobjekt. (Gregorianischer Kalender: eine Kalenderdarstellungsmethode, ähnlich dem Mondkalender unseres Landes, der in westlichen Ländern häufiger verwendet wird und hier nicht im Detail besprochen wird.)
Verwendungsbeispiel:
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
•Datum.Jahr, Datum.Monat, Datum.Tag: Jahr, Monat, Tag
•Datum. Ersetzen (Jahr, Monat, Tag): Erstellt ein neues Datumsobjekt und ersetzt die Attribute im Originalobjekt durch das durch die Parameter angegebene Jahr, den Monat und den Tag. (Das ursprüngliche Objekt bleibt unverändert)
•date.timetuple(): Gibt das time.struct_time-Objekt zurück, das dem Datum entspricht;
•date.toordinal(): Gibt das gregorianische Kalenderdatum zurück, das dem Datum entspricht; >• date.weekday(): Gibt den Wochentag zurück, wenn es Montag ist, gibt 0 zurück, wenn es Montag ist, usw.
•data.isoweekday(): Gibt den Wochentag zurück, wenn es Montag ist 1; Wenn es der 2. der Woche ist, geben Sie 2 zurück und so weiter; isoformat(): Gibt ein Tupel mit einem Format wie „JJJJ-MM-TT“ zurück.
•date.strftime(fmt): Benutzerdefinierte Formatzeichenfolge. Erklären Sie es unten ausführlich.
Verwendungsbeispiel:
Datum überlädt auch bestimmte Operationen, wodurch wir die folgenden Operationen an Datumsangaben ausführen können:
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
• timedelta = Datum1 - Datum2 # Subtrahieren Sie zwei Datumsangaben und geben Sie ein Zeitintervallobjekt zurück
•Datum1 < Datum2 # Vergleichen Sie zwei Datumsangaben
Hinweis: Achten Sie beim Arbeiten mit Datumsangaben darauf, dass das Datum den darstellbaren Bereich nicht überschreitet.
Verwendungsbeispiel:
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中文网!