2008-11-19 6 views
22

J'ai cette chaîne de date heure:Convertir une chaîne avec date et heure à une date

post["date"] = "2007-07-18 10:03:19" 

Je voudrais extraire juste « 2007-07-18 » comme une date. J'ai vu une référence à strptime mais je ne suis pas sûr de savoir comment l'utiliser. Comment puis-je extraire la date de cette chaîne?

+0

double possible de [date de Parse et le formater en utilisant python?] (Http://stackoverflow.com/questions/2265357/parse-date-and-format-it-using-python) – davidism

Répondre

54

Les deux autres réponses sont très bien, mais si vous voulez vraiment la date de quelque chose d'autre, vous pouvez utiliser le module datetime:

from datetime import datetime 
d = datetime.strptime('2007-07-18 10:03:19', '%Y-%m-%d %H:%M:%S') 
day_string = d.strftime('%Y-%m-%d') 

Il pourrait être surpuissant pour maintenant, mais ça va venir utile. Vous pouvez voir tous les spécificateurs de format here.

+0

pouvez-vous me dire le format de "Wed Dec 17 14:58:39 IST 2014"? –

+0

@DinoopNair cela devrait être le format que vous cherchez: "% a% b% d% H:% M:% S% Z% Y" –

7

Dans votre cas, il suffit d'utiliser fendu:

>>> d1="2007-07-18 10:03:19" 
>>> d1.split()[0] 
'2007-07-18' 
>>> 

(la 1ère partie après la séparation avec les espaces)

Si vous insistez sur l'utilisation strptime, le format est "%Y-%m-%d %H:%M:%S":

>>> import time 
>>> time.strptime(d1,"%Y-%m-%d %H:%M:%S") 
time.struct_time(tm_year=2007, tm_mon=7, tm_mday=18, tm_hour=10, tm_min=3, tm_sec=19, tm_wday=2, tm_yday=199, tm_isdst=-1) 
>>> time.strftime("%Y-%m-%d", _) 
'2007-07-18' 
>>> 
+2

pour éviter IndexError pour les données vides, vous pouvez utiliser 'd1.partition ('') [0]' – jfs

2

Probablement pas ce que vous cherchez, mais vous pouvez simplement diviser la chaîne:

post["date"].split()[0] 

vous donnera '2007-07-18'

1

Vous pouvez utiliser le module mx.DateTime de eGenix

import mx 

date_object = mx.DateTime.Parser.DateTimeFromString('2007-07-18 10:03:19') 
print "%s-%s-%s" % (date_object.year, date_object.month, date_object.day) 

Affichera: 2007-07-18

0

Vous pouvez utiliser le module parsedatetime.

>>> from parsedatetime.parsedatetime import Calendar 
>>> c = Calendar() 
>>> c.parse("2007-07-18 10:03:19") 
((2008, 11, 19, 10, 3, 19, 2, 324, 0), 2) 
2

Vous pouvez utiliser https://pypi.python.org/pypi/python-dateutil qui peut prendre en charge tout format datetime par exemple:

>>> from dateutil.parser import parse 
>>> d1="2007-07-18 10:03:19" 
>>> date_obj = parse(d1) 
>>> date_obj 
datetime.datetime(2007, 7, 18, 10, 3, 19) 
>>> date_obj.strftime("%Y-%m-%d") 
'2007-07-18' 
>>> d2 = "18-07-2007 10:03:19" 
>>> d = parse(d2) 
>>> d 
datetime.datetime(2007, 7, 18, 10, 3, 19) 
>>> d.strftime("%Y-%m-%d") 
'2007-07-18' 
0
import dateutil.parser 
a = "2007-07-18 10:03:19" 
d = dateutil.parser.parse(b).date() 

Votre sortie sera comme ça **

datetime.date (2007, 07, 18)

**

Questions connexes