Tutoriel d'intr...login
Tutoriel d'introduction de base à Python
auteur:php.cn  temps de mise à jour:2022-04-18 16:14:50

Date et heure Python


Les programmes Python peuvent gérer les dates et les heures de plusieurs manières, et la conversion des formats de date est une fonction courante.

Python fournit un module d'heure et de calendrier qui peut être utilisé pour formater les dates et les heures.

L'intervalle de temps est une fraction à virgule flottante en secondes.

Chaque horodatage est exprimé en fonction du temps écoulé depuis minuit (époque) le 1er janvier 1970.

Le module horaire de Python possède de nombreuses fonctions qui peuvent convertir les formats de date courants. Par exemple, la fonction time.time() est utilisée pour obtenir l'horodatage actuel, comme dans l'exemple suivant :


#!/usr/bin/python
# -*- coding: UTF-8 -*-

import time; #Introduire le module time

ticks = time.time()
print "L'horodatage actuel est :", ticks

L'exemple de résultat de sortie ci-dessus :

L'horodatage actuel est : 1459994552.51

L'unité d'horodatage est la plus appropriée pour opérations de dates. Mais les dates antérieures à 1970 ne peuvent pas être exprimées de cette manière. Les dates trop éloignées ne fonctionneront pas non plus, UNIX et Windows ne sont supportés que jusqu'en 2038.



Qu'est-ce qu'un tuple temporel ?

De nombreuses fonctions Python utilisent 9 groupes de temps de traitement numérique assemblés à partir d'un tuple :

序号字段
04位数年2008
11 到 12
21到31
3小时0到23
4分钟0到59
50到61 (60或61 是闰秒)
6一周的第几日0到6 (0是周一)
7一年的第几日1到366 (儒略历)
8夏令时-1, 0, 1, -1是决定是否为夏令时的旗帜

Ce qui précède est le tuple struct_time. Cette structure possède les propriétés suivantes :

序号属性
0tm_year2008
1tm_mon1 到 12
2tm_mday1 到 31
3tm_hour0 到 23
4tm_min0 到 59
5tm_sec0 到 61 (60或61 是闰秒)
6tm_wday0到6 (0是周一)
7tm_yday1 到 366(儒略历)
8tm_isdst-1, 0, 1, -1是决定是否为夏令时的旗帜


Obtenir l'heure actuelle

Convertissez de la méthode de suppression d'heure qui renvoie un nombre à virgule flottante en un tuple d'heure, transmettez simplement le nombre à virgule flottante à une fonction telle que l'heure locale.

#!/usr/bin/python
# -*- codage : UTF-8 -*-

heure d'importation

localtime = heure. localtime(time.time())
print "L'heure locale est :", localtime

L'exemple de résultat de sortie ci-dessus :

L'heure locale est : time.struct_time (tm_year=2016, tm_mon=4, tm_mday=7, tm_hour=10, tm_min=3, tm_sec=27, tm_wday=3, tm_yday=98, tm_isdst=0)


Obtenir l'heure formatée

Vous pouvez choisir différents formats en fonction de vos besoins, mais la fonction la plus simple pour obtenir un modèle d'heure lisible est asctime() :

# ! /usr/bin/python
# -*- codage : UTF-8 -*-

import time

localtime = time.asctime( time.localtime(time.time() ) )
imprimer "L'heure locale est :", heure locale

L'exemple de résultat de sortie ci-dessus :

L'heure locale est : jeu. 7 avril 10h05 :21 2016

Formater la date

On peut utiliser la méthode strftime du module time pour formater la date :

time.strftime (format[ , t])
#!/usr/bin/python
# -*- codage : UTF-8 -*-

heure d'importation

# Formaté en 2016-03 -20 11:45:39Format
print time.strftime("%Y-%m-%d %H:%M:%S", time.localtime())

# Formater en samedi 28 mars 22:24:24 2016Form
print time.strftime("%a %b %d %H:%M:%S %Y", time.localtime())

# Convertir la chaîne de format en horodatage
a = "Sam Mar 28 22:24:24 2016"
print time.mktime(time.strptime(a,"%a %b %d %H:%M :% S %Y"))

L'exemple de résultat de sortie ci-dessus :

2016-04-07 10:25:09
Jeudi 07 avril 10:25 : 09 2016
1459175064.0

Symboles de formatage de l'heure et de la date en python :

  • %y représentation de l'année à deux chiffres (00-99)

  • %Y Le L'année à quatre chiffres représente (000-9999)

  • %m mois (01-12)

  • %d jour du mois (0 -31)

  • %H heure de 24 heures (0-23)

  • %I heure de 12 heures (01 -12)

  • %M minutes (00=59)

  • %S secondes (00-59)

  • %a Nom de la semaine locale simplifiée

  • %A Nom de la semaine complète locale

  • %b Nom du mois local simplifié

  • %B nom complet du mois local

  • %c représentation locale de la date et de l'heure correspondantes

  • %j Jour de l'année ( 001-366)

  • %p Equivalent du matin ou de l'après-midi local

  • %U Année Le numéro de la semaine en (00-53) Le dimanche est le début de la semaine

  • %w semaine (0-6), le dimanche est le début de la semaine

  • %W Le nombre de semaines dans l'année (00-53) Le lundi est le début de la semaine

  • %x La représentation de la date locale correspondante

  • % X La représentation de l'heure locale correspondante

  • %Z Le nom du fuseau horaire actuel

  • %% Le nombre % lui-même


Obtenir le calendrier d'un certain mois

Le module Calendrier propose un large éventail de méthodes de traitement des calendriers annuels et mensuels, comme l'impression du calendrier mensuel d'un certain mois :

# !/usr/bin/python
# -*- codage : UTF-8 -*-

importer le calendrier

cal = calendrier. Month(2016, 1)
print "Ce qui suit génère le calendrier de janvier 2016 :"
print cal;

Le résultat de sortie de l'exemple ci-dessus :

Les sorties suivantes du calendrier pour janvier 2016 :
janvier 2016
Mo Tu We Th Fr Sa Di
1 2 3
4 5 6 7 8 9 10
11 12 13 14 15 16 17 19 20 21 22 23 24
25 26 27 28 29 30 31


Module Time

Le module Time contient les fonctions intégrées suivantes, à la fois pour le traitement du temps et la conversion du format de l'heure :

< tbody >
Numéro de sérieFonction et description
1time.altzone
序号函数及描述
1time.altzone
返回格林威治西部的夏令时地区的偏移秒数。如果该地区在格林威治东部会返回负值(如西欧,包括英国)。对夏令时启用地区才能使用。
2time.asctime([tupletime])
接受时间元组并返回一个可读的形式为"Tue Dec 11 18:07:14 2008"(2008年12月11日 周二18时07分14秒)的24个字符的字符串。
3time.clock( )
用以浮点数计算的秒数返回当前的CPU时间。用来衡量不同程序的耗时,比time.time()更有用。
4time.ctime([secs])
作用相当于asctime(localtime(secs)),未给参数相当于asctime()
5time.gmtime([secs])
接收时间辍(1970纪元后经过的浮点秒数)并返回格林威治天文时间下的时间元组t。注:t.tm_isdst始终为0
6time.localtime([secs])
接收时间辍(1970纪元后经过的浮点秒数)并返回当地时间下的时间元组t(t.tm_isdst可取0或1,取决于当地当时是不是夏令时)。
7time.mktime(tupletime)
接受时间元组并返回时间辍(1970纪元后经过的浮点秒数)。
8time.sleep(secs)
推迟调用线程的运行,secs指秒数。
9time.strftime(fmt[,tupletime])
接收以时间元组,并返回以可读字符串表示的当地时间,格式由fmt决定。
10time.strptime(str,fmt='%a %b %d %H:%M:%S %Y')
根据fmt的格式把一个时间字符串解析为时间元组。
11time.time( )
返回当前时间的时间戳(1970纪元后经过的浮点秒数)。
12time.tzset()
根据环境变量TZ重新初始化时间相关设置。
Renvoie le décalage en secondes pour le fuseau horaire d'été à l'ouest de Greenwich. Des valeurs négatives sont renvoyées si la zone est à l'est de Greenwich (comme l'Europe occidentale, y compris le Royaume-Uni). Disponible uniquement dans les régions où l’heure d’été est activée.
2time.asctime([tupletime])

Accepte un tuple temporel et renvoie une forme lisible de "Tue Dec 11 18 :07 :14 2008" (mardi 11 décembre 2008, 18:07:14) est une chaîne de 24 caractères.

3time.clock()

Renvoie le temps CPU actuel en secondes calculé sous forme de nombre à virgule flottante. Il est utilisé pour mesurer la consommation de temps de différents programmes et est plus utile que time.time().
4time.ctime([secs])
序号属性及描述
1time.timezone
属性time.timezone是当地时区(未启动夏令时)距离格林威治的偏移秒数(>0,美洲;<=0大部分欧洲,亚洲,非洲)。
2time.tzname
属性time.tzname包含一对根据情况的不同而不同的字符串,分别是带夏令时的本地时区名称,和不带的。
La fonction est équivalente à asctime(localtime(secs)). , ce qui équivaut à asctime ()
5time.gmtime([secs])<🎜>Délai d'expiration de réception (le nombre de secondes à virgule flottante écoulé depuis l'époque 1970) et renvoie un tuple temporel t en heure astronomique de Greenwich. Remarque : t.tm_isdst est toujours 0
6time.localtime([secs])<🎜>Le délai de réception expire après l'époque 1970 Flottant point secondes) et renvoie le tuple temporel t en heure locale (t.tm_isdst peut être 0 ou 1, selon que l'heure locale est l'heure d'été).
7time.mktime(tupletime)<🎜>Accepte un tuple temporel et renvoie l'heure (le nombre de secondes à virgule flottante écoulées depuis les années 1970 époque) .
8time.sleep(secs)<🎜>Différer l'exécution du thread appelant, secs fait référence au nombre de secondes.
9time.strftime(fmt[,tupletime])<🎜>Reçoit un tuple temporel et renvoie une chaîne lisible Heure locale, format déterminé par enfin.
10time.strptime(str,fmt='%a %b %d %H:%M:%S %Y')< 🎜>Analyser une chaîne temporelle en un tuple temporel selon le format fmt.
11time.time( )<🎜>Renvoie l'horodatage de l'heure actuelle (le nombre de secondes à virgule flottante écoulées depuis l'époque 1970) .
12time.tzset()<🎜>Réinitialisez les paramètres liés au temps en fonction de la variable d'environnement TZ.
<🎜>Le module Time contient les 2 attributs très importants suivants : <🎜>
Numéro de sérieAttributs et description
1time.timezone<🎜>La propriété time.timezone est le décalage en secondes du fuseau horaire local (sans heure d'été) à partir de Greenwich (>0, Amérique;<= (la majeure partie de l'Europe, de l'Asie et de l'Afrique).
2time.tzname<🎜>L'attribut time.tzname contient une paire de caractères qui varient en fonction du situation Les chaînes sont les noms de fuseau horaire local avec et sans heure d'été.


Module Calendrier

Les fonctions de ce module sont toutes liées au calendrier, comme l'impression du calendrier des personnages d'un certain mois.

Le lundi est le premier jour de la semaine par défaut et le dimanche est le dernier jour par défaut. Pour modifier les paramètres, vous devez appeler la fonction calendrier.setfirstweekday(). Le module contient les fonctions intégrées suivantes :

< th style=" width:95%">Fonction et description
Numéro de série
1calendar.calendar(year,w=2,l= 1,c= 6)
序号函数及描述
1calendar.calendar(year,w=2,l=1,c=6)
返回一个多行字符串格式的year年年历,3个月一行,间隔距离为c。 每日宽度间隔为w字符。每行长度为21* W+18+2* C。l是每星期行数。
2calendar.firstweekday( )
返回当前每周起始日期的设置。默认情况下,首次载入caendar模块时返回0,即星期一。
3calendar.isleap(year)
是闰年返回True,否则为false。
4calendar.leapdays(y1,y2)
返回在Y1,Y2两年之间的闰年总数。
5calendar.month(year,month,w=2,l=1)
返回一个多行字符串格式的year年month月日历,两行标题,一周一行。每日宽度间隔为w字符。每行的长度为7* w+6。l是每星期的行数。
6calendar.monthcalendar(year,month)
返回一个整数的单层嵌套列表。每个子列表装载代表一个星期的整数。Year年month月外的日期都设为0;范围内的日子都由该月第几日表示,从1开始。
7calendar.monthrange(year,month)
返回两个整数。第一个是该月的星期几的日期码,第二个是该月的日期码。日从0(星期一)到6(星期日);月从1到12。
8calendar.prcal(year,w=2,l=1,c=6)
相当于 print calendar.calendar(year,w,l,c).
9calendar.prmonth(year,month,w=2,l=1)
相当于 print calendar.calendar(year,w,l,c)。
10calendar.setfirstweekday(weekday)
设置每周的起始日期码。0(星期一)到6(星期日)。
11calendar.timegm(tupletime)
和time.gmtime相反:接受一个时间元组形式,返回该时刻的时间辍(1970纪元后经过的浮点秒数)。
12calendar.weekday(year,month,day)
返回给定日期的日期码。0(星期一)到6(星期日)。月份为 1(一月) 到 12(12月)。
Renvoie un calendrier annuel au format chaîne multiligne, avec 3 mois par ligne et un intervalle de c. L'intervalle de largeur quotidien est de w caractères. La longueur de chaque ligne est de 21* W+18+2* C. l est le nombre de lignes par semaine.
2calendar.firstweekday( )
Renvoie le paramètre du jour de début hebdomadaire actuel. Par défaut, 0 est renvoyé lors du premier chargement du module caendar, c'est-à-dire lundi.
3calendar.isleap(year)
Renvoie True s'il s'agit d'une année bissextile, sinon false.
4calendar.leapdays(y1,y2)

Renvoie les deux années entre Y1 et Y2 Nombre total des années bissextiles.

5calendar.month(year,month,w=2,l=1)Renvoyer un Calendrier annuel et mensuel au format chaîne multiligne, avec deux lignes de titres et une ligne pour chaque semaine. L'intervalle de largeur quotidien est de w caractères. La longueur de chaque ligne est de 7* w+6. l est le nombre de lignes par semaine.
6calendar.monthcalendar(year,month)

Renvoie une liste imbriquée d'entiers à un seul niveau. Chaque sous-liste contient un entier représentant une semaine. Les dates en dehors de l'année, du mois et du mois sont toutes définies sur 0 ; les jours compris dans la plage sont représentés par le jour du mois, à partir de 1.

7calendar.monthrange(year,month)

Renvoie deux entiers. Le premier est le code de date du jour de la semaine du mois et le second est le code de jour du mois. Les jours vont de 0 (lundi) à 6 (dimanche) ; les mois vont de 1 à 12.
8calendar.prcal(année,w=2,l=1,c=6)
    Équivalent à imprimer calendrier.calendar(année,w,l,c).
9calendar.prmonth(année,mois,s =2,l=1)
  • Équivalent à imprimer calendrier.calendar(année, w, l, c).
  • 10calendar.setfirstweekday(weekday)

    Définissez le code du jour de début de la semaine. 0 (lundi) à 6 (dimanche).

    11calendar.timegm(tupletime)

    L'opposé de time.gmtime : accepte une forme de tuple temporel , renvoie l'heure à ce moment (le nombre de secondes à virgule flottante écoulées depuis l'époque 1970).
    12calendar.weekday(year,month,day)Renvoie le code de date de la date donnée . 0 (lundi) à 6 (dimanche). Les mois vont du 1 (janvier) au 12 (décembre).
  • Autres modules et fonctions associés
  • En Python, les autres modules de traitement des dates et des heures sont :

  • module datetime
    <🎜><🎜>module pytz<🎜><🎜><🎜><🎜>module dateutil<🎜><🎜><🎜 >< 🎜><🎜>