Python строка даты для объекта даты


346

Как мне преобразовать строку в объект даты в python?

Строка будет: "24052010"( что соответствует формату: "%d%m%Y")

Я не хочу объект datetime.datetime, а скорее datetime.date.

Ответы:


587

Вы можете использовать strptimeв datetimeпакете Python:

>>> import datetime
>>> datetime.datetime.strptime('24052010', "%d%m%Y").date()
datetime.date(2010, 5, 24)

Я пытаюсь выполнить аналогичный процесс, за исключением того, что у моей входной строки нет года, поэтому она выглядит как «2405». По умолчанию год принимается за 1900. Проблема возникает при разборе даты февраля, например «2902». Я получаю эту ошибку ValueError: day is out of range for month. Не уверен, как я могу установить год по умолчанию при разборе.
Шубхам Найк


59

Непосредственно связанный вопрос:

Что делать, если у вас есть

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))

1
2015-07-20 09: 46: 55 + 00: 00 У меня есть такие данные. Как получить объект даты?
Хардик Гаджар

Используйте модуль re (регулярное выражение), чтобы изменить ваши данные с «2015-07-20 09: 46: 55 + 00: 00» на «2015-07-20T09: 46: 55-00: 00». Затем используйте dateutil.parse для получения объекта даты.
Шопенгауэр

1
Спасибо, на самом деле проблема была в объекте типа dict, и я просто получаю решение, используя dict.get, используя
Hardik Gajjar

2
Другая идея - прочитать руководство docs.python.org/3/library/… и заметить, что% B означает «Месяц как полное имя локали». который похож на "январь" или "декабрь", поэтому "02" не собирается анализировать.
Флип

1
Строка формата даты в этом является неправильной, это должен быть% m, а не% B
theannouncer

24

Если вы ленивы и не хотите бороться со строковыми литералами, вы можете просто пойти с 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


очень простое решение, спасибо. Я пытался преобразовать длинную дату Excel, которая отображалась какMonday, June 03, 2019
Джефф

5

у вас есть строка даты, как это, «24052010», и вы хотите объект даты для этого,

from datetime import datetime
cus_date = datetime.strptime("24052010", "%d%m%Y").date()

это cus_date даст вам объект даты.

вы можете получить строку даты из вашего объекта даты, используя это,

cus_date.strftime("%d%m%Y")

3

Есть еще одна библиотека, которая arrowдействительно отлично подходит для манипулирования датой Python.

import arrow
import datetime

a = arrow.get('24052010', 'DMYYYY').date()
print(isinstance(a, datetime.date)) # True

1

Используйте временной модуль для преобразования данных.

Фрагмент кода:

import time 
tring='20150103040500'
var = int(time.mktime(time.strptime(tring, '%Y%m%d%H%M%S')))
print var
Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.