Відповіді:
import datetime
datetime.datetime.strptime('24052010', '%d%m%Y').date()
Прямо пов'язане питання:
Що робити, якщо є
datetime.datetime.strptime("2015-02-24T13:00:00-08:00", "%Y-%B-%dT%H:%M:%S-%H:%M").date()
і ви отримуєте:
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
і ти спробував:
<-24T13:00:00-08:00", "%Y-%B-%dT%HH:%MM:%SS-%HH:%MM").date()
але ви все одно отримаєте прослідку вище.
Відповідь:
>>> 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))
Якщо ви лінивий і не хочете боротися зі строковими літералами, можете просто перейти з parser
модулем.
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
Тільки бічна примітка , оскільки ми намагаємося відповідати any
рядковій репрезентації, це в 10 разів повільніше, ніжstrptime
Monday, June 03, 2019
у вас є такий рядок дати, як "24052010", і ви хочете для цього об'єкт дати,
from datetime import datetime
cus_date = datetime.strptime("24052010", "%d%m%Y").date()
цей cus_date дасть вам об’єкт дати.
ви можете отримати рядок дати з об’єкта дати за допомогою цього,
cus_date.strftime("%d%m%Y")
1900
. Проблема виникає під час розбору дати лютого типу "2902". Я отримую цю помилкуValueError: day is out of range for month
. Не впевнений, як я можу встановити рік за замовчуванням під час розбору.