Heim  >  Artikel  >  Backend-Entwicklung  >  Referenzhandbuch für das Datetime-Modul in Python

Referenzhandbuch für das Datetime-Modul in Python

高洛峰
高洛峰Original
2017-01-14 16:19:501316Durchsuche

Vorwort

Python bietet mehrere integrierte Module zum Bearbeiten von Datum und Uhrzeit, z. B. Kalender, Uhrzeit und Datum/Uhrzeit. Die vom Zeitmodul bereitgestellte Schnittstelle stimmt grundsätzlich mit der C-Standardbibliothek time.h überein. Im Vergleich zum Zeitmodul ist die Schnittstelle des Datums-/Uhrzeitmoduls intuitiver und einfacher aufzurufen. Das Modul

definiert zwei Konstanten:

datetime.MINYEAR

datetime.MAXYEAR

Diese beiden Konstanten stellen jeweils dar, was datetime darstellen kann. Das Minimum und maximales Jahr. Darunter ist MINYEAR = 1, MAXYEAR = 9999.

datetime-Modul definiert die folgenden Klassen:

datetime.date: Klasse, die das Datum darstellt. Zu den häufig verwendeten Attributen gehören Jahr, Monat, 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: Relevante Informationen zu Zeitzonen.

Hinweis: Die oben aufgeführten Objekttypen sind alle unveränderlich.

Datumsklasse

Datumsklasse stellt ein Datum dar (bestehend aus Jahr, Monat, Tag) und ihr Prototyp lautet wie folgt:

Klasse datetime.date( Jahr, Monat, Tag)

Parameterbeschreibung: Der Bereich von

Jahr ist [MINYEAR, MAXYEAR], also [1, 9999];

Monat ist [1 , 12]. (Der Monat beginnt bei 1, nicht bei 0); Der Maximalwert von

Tag 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 -attribute:


date.max, date.min: welche Datumsobjekte kann maximale und minimale Daten darstellen;

date.resolution: Das Datumsobjekt stellt die kleinste Datumseinheit 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; 🎜>datetime.fromordinal(ordinal): Konvertieren Sie die gregorianische Kalenderzeit in ein Datumsobjekt. (Gregorianischer Kalender: eine Kalenderdarstellungsmethode, ähnlich dem Mondkalender unseres Landes, der in westlichen Ländern häufig verwendet wird und hier nicht im Detail besprochen wird.)

Verwendungsbeispiel:

>>> datetime.date.max
datetime.date(9999, 12, 31)
>>> datetime.date.min
datetime.date(1, 1, 1)
>>> datetime.date.resolution
datetime.timedelta(1)
>>> datetime.date.today()
datetime.date(2016, 5, 12)
>>> datetime.date.fromtimestamp(time.time())
datetime.date(2016, 5, 12)

Instanzmethoden und -eigenschaften bereitgestellt nach Datum:

Datum.Jahr , date.month, date.day: Jahr, Monat, Tag;

date.replace(Jahr, Monat, Tag): Erzeugt ein neues Datumsobjekt und ersetzt das ursprüngliche durch Jahr, Monat und Tag durch die Parameter Eigenschaften im Objekt angegeben. (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;

date.weekday(): Gibt den Wochentag zurück, wenn es Montag ist, gibt 0 zurück, wenn es Dienstag ist, und so weiter.

data.isoweekday(): Gibt zurück Wochentag: Wenn es Montag ist, geben Sie 1 zurück. Wenn es Dienstag ist, geben Sie 2 zurück.

date.isocalendar(): Geben Sie ein Tupel im Format (Jahr, Monat, Tag) zurück 🎜>

date.isoformat(): Gibt eine Zeichenfolge im Format „JJJJ-MM-TT“ zurück;

date.strftime(fmt): Benutzerdefinierte Formatzeichenfolge.

Verwendungsbeispiel:


>>> today = datetime.date.today()
>>> today.year
2016
>>> today.month
5
>>> today.day
12
>>> tomorrow = today.replace(day=13)
>>> tomorrow
datetime.date(2016, 5, 13)
>>> tomorrow.timetuple()
time.struct_time(tm_year=2016, tm_mon=5, tm_mday=13, tm_hour=0, tm_min=0, tm_sec=0, tm_wday=4, tm_yday=134, tm_isdst=-1)
>>> tomorrow.toordinal()
736097
>>> tomorrow.weekday()
4
>>> tomorrow.isoweekday()
5
>>> tomorrow.isocalendar()
(2016, 19, 5)
>>> tomorrow.isoformat()
'2016-05-13'
>>> tomorrow.strftime("%y-%m-%d")
'16-05-13'
Datum überladen, einfacher Operator:


Datum erlaubt Addieren, Subtrahieren und Daten vergleichen:


Datum2 = Datum1 + Zeitdelta:

Datum plus ein Intervall, ein neues Datumsobjekt zurückgeben


Datum2 = Datum1 - Zeitdelta:

Das Datum wird durch ein Intervall getrennt und gibt ein neues Datumsobjekt zurück


timedelta = date1 - date2:

Subtrahiere zwei Datumsangaben, gib ein Zeitintervallobjekt zurück


Datum1 < Datum2:

um zwei Daten zu vergleichen.


Verwendungsbeispiel:

>>> now = datetime.date.today()
>>> now
datetime.date(2016, 5, 12)
>>> now += datetime.date.resolution
>>> now
datetime.date(2016, 5, 13)
>>> now -= datetime.date.resolution
>>> now
datetime.date(2016, 5, 12)
>>> now < datetime.date.max
True
Zeitklasse


Die Zeitklasse repräsentiert die Zeit (bestehend aus Stunden, Minuten, Sekunden und besteht aus Mikrosekunden), sein Prototyp lautet wie folgt:


class datetime.time(hour=0, minute=0, second=0, microsecond=0, tzinfo=None)

Parameter Hinweis: Der Bereich von


Stunde ist [0, 24), der Bereich von

Minute ist [0, 60), der Bereich von

Sekunde ist [0, 60),

Der Mikrosekundenbereich beträgt [0, 1000000),

tzinfo stellt Zeitzoneninformationen dar.

Durch die Zeitklasse definierte Klassenattribute:


time.min, time.max: die minimale und maximale Zeit, die die Zeitklasse darstellen kann. Darunter time.min = time(0, 0, 0, 0), time.max = time(23, 59, 59, 999999);


time.resolution: hier die kleinste Zeiteinheit beträgt 1 Mikrosekunden;

Anwendungsbeispiel:


>>> datetime.time.min
datetime.time(0, 0)
>>> datetime.time.max
datetime.time(23, 59, 59, 999999)
>>> datetime.time.resolution
datetime.timedelta(0, 0, 1)
Von der Zeitklasse bereitgestellte Instanzmethoden und Eigenschaften:


time.hour, time.minute, time.second, time.microsecond: Stunden, Minuten, Sekunden, Mikrosekunden;


time.tzinfo: Zeitzoneninformationen; ([ Stunde[, Minute[, Sekunde[, Mikrosekunde[, tzinfo]]]]]): Erstellen Sie ein neues Zeitobjekt und ersetzen Sie die Attribute im Originalobjekt durch die durch die Parameter angegebenen Stunden, Minuten, Sekunden und Mikrosekunden ( das ursprüngliche Objekt bleibt unverändert);

time.isoformat(): gibt eine Zeichenfolgendarstellung im Format „HH:MM:SS“ zurück;

time.strftime(fmt): gibt a zurück angepasste Formatzeichenfolge.

Verwendungsbeispiel:


Objekte der Zeitklasse können nur verglichen und nicht addiert oder subtrahiert werden.

>>> tm = datetime.time(18, 18, 18)
>>> tm.hour
18
>>> tm.minute
18
>>> tm.second
18
>>> tm.microsecond
0
>>> tm.tzinfo
>>> tm.isoformat()
&#39;18:18:18&#39;
>>> tm.replace(hour=20)
datetime.time(20, 18, 18)
>>> tm.strftime("%I:%M:%S %p")
&#39;06:18:18 PM&#39;
datetime-Klasse


datetime ist eine Kombination aus Datum und Uhrzeit, einschließlich aller Informationen zu Datum und Uhrzeit. Der Prototyp lautet wie folgt:


各参数的含义与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对象,data 与 time 类没有提供该方法。

使用示例:

>>> datetime.datetime.min
datetime.datetime(1, 1, 1, 0, 0)
>>> datetime.datetime.max
datetime.datetime(9999, 12, 31, 23, 59, 59, 999999)
>>> datetime.datetime.resolution
datetime.timedelta(0, 0, 1)
>>> print datetime.datetime.resolution
0:00:00.000001
>>> today = datetime.datetime.today()
>>> today
datetime.datetime(2016, 5, 12, 12, 46, 47, 246240)
>>> datetime.datetime.now()
datetime.datetime(2016, 5, 12, 12, 47, 9, 850643)
>>> datetime.datetime.utcnow()
datetime.datetime(2016, 5, 12, 4, 47, 42, 188124)
>>> datetime.datetime.fromtimestamp(time.time())
datetime.datetime(2016, 5, 12, 12, 48, 40, 459676)
>>> datetime.datetime.combine(datetime.date(1990, 10, 05), datetime.time(18, 18, 18))
datetime.datetime(1990, 10, 5, 18, 18, 18)
>>> datetime.datetime.strptime("2010-04-07 01:48:16.234000", "%Y-%m-%d %H:%M:%S .%f")
datetime.datetime(2010, 4, 7, 1, 48, 16, 234000)


datetime 的实例方法与属性

datetime类提供的实例方法与属性大部分功能与 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)

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

timedelta 类

datetime.timedelta 对象代表两个时间之间的的时间差,两个 date 或 datetime 对象相减时可以返回一个timedelta 对象。其原型如下:

class datetime.timedelta(days=0, seconds=0, microseconds=0, milliseconds=0, minutes=0, hours=0, weeks=0)

   


所有参数可选,且默认都是0,参数的值可以是整数,浮点数,正数或负数。

内部只存储days,seconds,microseconds,其他参数的值会自动按如下规则抓转换:

1 millisecond(毫秒) 转换成 1000 microseconds(微秒)

1 minute 转换成 60 seconds

1 hour 转换成 3600 seconds

1 week转换成 7 days

三个参数的取值范围分别为:

0 <= microseconds < 1000000

0 <= seconds < 3600*24 (the number of seconds in one day)

-999999999 <= days <= 999999999

timedelta 类定义的类属性:

timedelta.min:时间间隔对象的最小值,即 timedelta(-999999999).

timedelta.max:时间间隔对象的最大值,即 timedelta(days=999999999, hours=23, minutes=59, seconds=59, microseconds=999999).

timedelta.resolution:时间间隔的最小单位,即 timedelta(microseconds=1).

使用示例:

>>> datetime.timedelta.min
datetime.timedelta(-999999999)
>>> datetime.timedelta.max
datetime.timedelta(999999999, 86399, 999999)
>>> datetime.timedelta.resolution
datetime.timedelta(0, 0, 1)
>>> print datetime.timedelta.resolution
0:00:00.000001


timedelta 实例方法

timedelta.total_seconds():计算时间间隔的总秒数

使用示例:

>>> datetime.timedelta.resolution.total_seconds()
1e-06


格式字符串

datetime、date、time 都提供了 strftime() 方法,该方法接收一个格式字符串,输出日期时间的字符串表示。支持的转换格式如下:

%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.datetime.now()
>>> dt.strftime(&#39;%Y-%m-%d %H:%M:%S %f&#39;)
&#39;2016-05-12 14:19:22 333943&#39;
>>> dt.strftime(&#39;%y-%m-%d %I:%M:%S %p&#39;)
&#39;16-05-12 02:19:22 PM&#39;
>>> dt.strftime("%a")
&#39;Thu&#39;
>>> dt.strftime("%A")
&#39;Thursday&#39;
>>> dt.strftime("%b")
&#39;May&#39;
>>> dt.strftime("%B")
&#39;May&#39;
>>> dt.strftime("%c")
&#39;Thu May 12 14:19:22 2016&#39;
>>> dt.strftime("%x")
&#39;05/12/16&#39;
>>> dt.strftime("%X")
&#39;14:19:22&#39;
>>> dt.strftime("%w")
&#39;4&#39;
>>> dt.strftime("%j")
&#39;133&#39;
>>> dt.strftime("%u")
&#39;4&#39;
>>> dt.strftime("%U")
&#39;19&#39;


总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。

更多Python中datetime模块参考手册相关文章请关注PHP中文网!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn