Разобрать строку даты и изменить формат


115

У меня есть строка даты в формате «Пн, 15 февраля 2010 г.». Я хочу изменить формат на «15/02/2010». Как я могу это сделать?


Дубликат всего этого: stackoverflow.com/search?q=%5Bpython%5D+parse+date . Точная копия этого: stackoverflow.com/questions/1713594/…
S.Lott

Ответы:


153

datetime модуль может помочь вам в этом:

datetime.datetime.strptime(date_string, format1).strftime(format2)

Для конкретного примера вы могли бы сделать

>>> datetime.datetime.strptime('Mon Feb 15 2010', '%a %b %d %Y').strftime('%d/%m/%Y')
'15/02/2010'
>>>

2
datetime.datetime (понедельник, 15 февраля 2010 г., «% a% b% d% Y»). strftime («% d /% m /% Y») Это правильно? но у меня ошибка.
Нимми

1
@nimmyliji: это было исправлено за 10 минут до того, как вы разместили свой комментарий. и, конечно, вы должны иметь date_stringстроку.
SilentGhost

3
пожалуйста, полностью рабочий пример;) какой импорт / ... требуется?
codeling

format1должен быть строкой для выражения формата строки даты ввода. format2- формат целевой строки для вывода.
ThorSummoner

1
Не могли бы вы подробнее рассказать, как должен выглядеть format1 в этом примере?
user1767754

59

Вы можете установить библиотеку dateutil . Его parseфункция может определить, в каком формате находится строка, без необходимости указывать формат, как это делаете вы datetime.strptime.

from dateutil.parser import parse
dt = parse('Mon Feb 15 2010')
print(dt)
# datetime.datetime(2010, 2, 15, 0, 0)
print(dt.strftime('%d/%m/%Y'))
# 15/02/2010

dateutil.parse - лучшая альтернатива, если точный формат допустимой строки ISO неизвестен. ISO может содержать или не содержать микросекунды. Он может содержать или не содержать букву "Z" в конце. datetime.strptime недостаточно гибок, чтобы приспособиться к этому.
Майкл Карив

4
Pase Date следует использовать с осторожностью. parse ('12 .07.2017 ') возвращает datetime (2017, 12, 7, ..), но parse ('13 .07.2017') возвращает .datetime (2017, 7, 13, ...)
ego2dot0

В python 3.xпотребности установитьpython-dateutil pip install python-dateutil
AB абхи


23

преобразовать строку в объект datetime

from datetime import datetime
s = "2016-03-26T09:25:55.000Z"
f = "%Y-%m-%dT%H:%M:%S.%fZ"
out = datetime.strptime(s, f)
print(out)
output:
2016-03-26 09:25:55

Это не соответствует формату, который он спросил, в котором была строка месяца «Фев».
Шахир Ансари

@ShahirAnsari, вы можете изменить формат по своему усмотрению, см. " Docs.python.org/3/library/datetime.html "
anjaneyulubatta505

14

Поскольку этот вопрос возникает часто, вот простое объяснение.

datetime или time модуль выполняет две важные функции.

  • strftime - создает строковое представление даты или времени из объекта datetime или time.
  • strptime - создает объект datetime или time из строки.

В обоих случаях нам нужна формирующая строка. Это представление, которое сообщает, как дата или время форматируются в вашей строке.

Теперь предположим, что у нас есть объект даты.

>>> from datetime import datetime
>>> d = datetime(2010, 2, 15)
>>> d
datetime.datetime(2010, 2, 15, 0, 0)

Если мы хотим создать строку из этой даты в формате 'Mon Feb 15 2010'

>>> s = d.strftime('%a %b %d %y')
>>> print s
Mon Feb 15 10

Предположим, мы хотим снова преобразовать это sв datetimeобъект.

>>> new_date = datetime.strptime(s, '%a %b %d %y')
>>> print new_date
2010-02-15 00:00:00

Обратитесь к этому документу со всеми директивами форматирования, касающимися datetime.


Мне нравится ваше объяснение.
enchance

2

Просто ради завершения: при синтаксическом анализе даты с использованием strptime()даты, содержащей название дня, месяца и т. Д., Имейте в виду, что вы должны учитывать языковой стандарт.

Это также упоминается как сноска в документации .

Например:

import locale
print(locale.getlocale())

>> ('nl_BE', 'ISO8859-1')

from datetime import datetime
datetime.strptime('6-Mar-2016', '%d-%b-%Y').strftime('%Y-%m-%d')

>> ValueError: time data '6-Mar-2016' does not match format '%d-%b-%Y'

locale.setlocale(locale.LC_ALL, 'en_US')
datetime.strptime('6-Mar-2016', '%d-%b-%Y').strftime('%Y-%m-%d')

>> '2016-03-06'

2

@codeling и @ user1767754: следующие две строки будут работать. Я видел, что никто не опубликовал полное решение заданной проблемы. Надеюсь, этого достаточно.

import datetime

x = datetime.datetime.strptime("Mon Feb 15 2010", "%a %b %d %Y").strftime("%d/%m/%Y")
print(x)

Вывод:

15/02/2010

1

Вы также можете добиться этого с помощью панд:

import pandas as pd

pd.to_datetime('Mon Feb 15 2010', format='%a %b %d %Y').strftime('%d/%m/%Y')

Вывод:

'15/02/2010'

Вы можете применить подход pandas для разных типов данных, как:

import pandas as pd
import numpy as np

def reformat_date(date_string, old_format, new_format):
    return pd.to_datetime(date_string, format=old_format, errors='ignore').strftime(new_format)

date_string = 'Mon Feb 15 2010'
date_list = ['Mon Feb 15 2010', 'Wed Feb 17 2010']
date_array = np.array(date_list)
date_series = pd.Series(date_list)

old_format = '%a %b %d %Y'
new_format = '%d/%m/%Y'

print(reformat_date(date_string, old_format, new_format))
print(reformat_date(date_list, old_format, new_format).values)
print(reformat_date(date_array, old_format, new_format).values)
print(date_series.apply(lambda x: reformat_date(x, old_format, new_format)).values)

Вывод:

15/02/2010
['15/02/2010' '17/02/2010']
['15/02/2010' '17/02/2010']
['15/02/2010' '17/02/2010']

0

используйте библиотеку datetime http://docs.python.org/library/datetime.html найдите 9.1.7. especiall strptime () strftime () Поведение¶ примеры http://pleac.sourceforge.net/pleac_python/datesandtimes.html


для ошибки выше nimmyliji вы должны были сделать datetime.datetime.strptime ("Mon Feb 15 2010", "% a% b% d% Y"). strftime ("% d /% m /% Y") он дает ' 15/02/2010 '
Роман А. Тайчер
Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.