Пам'ятайте про це, і вам не потрібно було знову плутатись у перетворенні дат.
Рядок до об'єкта datetime = strptime
об'єкт datetime в інших форматах = strftime
Jun 1 2005 1:33PM
дорівнює
%b %d %Y %I:%M%p
% b Місяць як скорочена назва локалу (червень)
% d День місяця у вигляді нульового десяткового числа (1)
% Y Рік із століттям у вигляді десяткового числа (2015)
% I Hour (12-годинний годинник) у вигляді десяткового числа (01)
% M Хвилина у вигляді нульового десяткового числа (33)
% p Локальний еквівалент AM або PM (PM)
тому вам потрібен strptime, тобто перетворення string
в
>>> dates = []
>>> dates.append('Jun 1 2005 1:33PM')
>>> dates.append('Aug 28 1999 12:00AM')
>>> from datetime import datetime
>>> for d in dates:
... date = datetime.strptime(d, '%b %d %Y %I:%M%p')
... print type(date)
... print date
...
Вихідні дані
<type 'datetime.datetime'>
2005-06-01 13:33:00
<type 'datetime.datetime'>
1999-08-28 00:00:00
Що робити, якщо у вас різний формат дат, ви можете використовувати panda або dateutil.parse
>>> import dateutil
>>> dates = []
>>> dates.append('12 1 2017')
>>> dates.append('1 1 2017')
>>> dates.append('1 12 2017')
>>> dates.append('June 1 2017 1:30:00AM')
>>> [parser.parse(x) for x in dates]
OutPut
[datetime.datetime(2017, 12, 1, 0, 0), datetime.datetime(2017, 1, 1, 0, 0), datetime.datetime(2017, 1, 12, 0, 0), datetime.datetime(2017, 6, 1, 1, 30)]
strptime()
буде ганяти вас горіхами, якщо ви не загорнете його. Дивіться мою відповідь, що грунтується на відповіді або Weis на це