Risposte:
import datetime
datetime.datetime.strptime('24052010', '%d%m%Y').date()
Domanda direttamente correlata:
E se lo hai
datetime.datetime.strptime("2015-02-24T13:00:00-08:00", "%Y-%B-%dT%H:%M:%S-%H:%M").date()
e ottieni:
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "/usr/local/lib/python2.7/_strptime.py", line 308, in _strptime
format_regex = _TimeRE_cache.compile(format)
File "/usr/local/lib/python2.7/_strptime.py", line 265, in compile
return re_compile(self.pattern(format), IGNORECASE)
File "/usr/local/lib/python2.7/re.py", line 194, in compile
return _compile(pattern, flags)
File "/usr/local/lib/python2.7/re.py", line 251, in _compile
raise error, v # invalid expression
sre_constants.error: redefinition of group name 'H' as group 7; was group 4
e hai provato:
<-24T13:00:00-08:00", "%Y-%B-%dT%HH:%MM:%SS-%HH:%MM").date()
ma ottieni ancora il traceback sopra.
Risposta:
>>> from dateutil.parser import parse
>>> from datetime import datetime
>>> parse("2015-02-24T13:00:00-08:00")
datetime.datetime(2015, 2, 24, 13, 0, tzinfo=tzoffset(None, -28800))
Se sei pigro e non vuoi combattere con i letterali per archi, puoi semplicemente andare con il parser
modulo.
from dateutil import parser
dt = parser.parse("Jun 1 2005 1:33PM")
print(dt.year, dt.month, dt.day,dt.hour, dt.minute, dt.second)
>2005 6 1 13 33 0
Solo una nota a margine , poiché stiamo cercando di abbinare any
la rappresentazione di stringhe, è 10 volte più lenta distrptime
Monday, June 03, 2019
hai una stringa di date come questa, "24052010" e vuoi un oggetto data per questo,
from datetime import datetime
cus_date = datetime.strptime("24052010", "%d%m%Y").date()
questo cus_date ti darà l'oggetto data.
puoi recuperare la stringa di data dal tuo oggetto data usando questo,
cus_date.strftime("%d%m%Y")
1900
. Il problema si verifica durante l'analisi della data di febbraio come "2902". Ottengo questo erroreValueError: day is out of range for month
. Non sono sicuro di come posso impostare l'anno predefinito durante l'analisi.