Respostas:
import datetime
datetime.datetime.strptime('24052010', '%d%m%Y').date()
Pergunta diretamente relacionada:
E se você tiver
datetime.datetime.strptime("2015-02-24T13:00:00-08:00", "%Y-%B-%dT%H:%M:%S-%H:%M").date()
e você obtém:
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 você tentou:
<-24T13:00:00-08:00", "%Y-%B-%dT%HH:%MM:%SS-%HH:%MM").date()
mas você ainda recebe o rastreio acima.
Responda:
>>> 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 você é preguiçoso e não quer lutar com literais de string, basta ir com o 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
Apenas uma observação : como estamos tentando corresponder à any
representação de strings, é 10 vezes mais lenta questrptime
Monday, June 03, 2019
você tem uma sequência de datas como esta, "24052010" e deseja um objeto de data para isso,
from datetime import datetime
cus_date = datetime.strptime("24052010", "%d%m%Y").date()
este cus_date fornecerá o objeto date.
você pode recuperar a sequência de datas do seu objeto de data usando isso,
cus_date.strftime("%d%m%Y")
1900
. O problema ocorre ao analisar a data de fevereiro como '2902'. Eu recebo esse erroValueError: day is out of range for month
. Não tenho certeza de como posso definir o ano padrão durante a análise.