Respuestas:
import datetime
datetime.datetime.strptime('24052010', '%d%m%Y').date()
Pregunta directamente relacionada:
¿Qué pasa si tienes
datetime.datetime.strptime("2015-02-24T13:00:00-08:00", "%Y-%B-%dT%H:%M:%S-%H:%M").date()
y obtienes:
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 intentaste:
<-24T13:00:00-08:00", "%Y-%B-%dT%HH:%MM:%SS-%HH:%MM").date()
pero aún obtienes el rastreo anterior.
Responder:
>>> 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))
Si eres perezoso y no quieres pelear con literales de cadena, puedes ir con el parser
módulo.
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 al margen , ya que estamos tratando de hacer coincidir la any
representación de cadena, es 10 veces más lenta questrptime
Monday, June 03, 2019
tiene una cadena de fecha como esta, "24052010" y desea un objeto de fecha para esto,
from datetime import datetime
cus_date = datetime.strptime("24052010", "%d%m%Y").date()
este cus_date le dará un objeto de fecha.
puedes recuperar la cadena de fecha de tu objeto de fecha usando esto,
cus_date.strftime("%d%m%Y")
1900
. El problema ocurre al analizar la fecha de febrero como '2902'. Me sale este errorValueError: day is out of range for month
. No estoy seguro de cómo puedo configurar el año predeterminado al analizar.