Python日付文字列から日付オブジェクト


345

Pythonで文字列を日付オブジェクトに変換するにはどうすればよいですか?

文字列は次のようになります"24052010"(形式:に対応"%d%m%Y"

datetime.datetimeオブジェクトではなく、datetime.dateが必要です。

回答:


586

Python strptimedatetimeパッケージで使用できます。

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

入力文字列に年がないため、「2405」のように見えることを除いて、同様のプロセスを試しています。デフォルトでは、年はと見なされ1900ます。この問題は、「2902」のような2月の日付を解析するときに発生します。このエラーが発生しますValueError: day is out of range for month。解析中にデフォルトの年をどのように設定できるかわかりません。
Shubham Naik


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私はこの種のデータを持っています、どのように日付オブジェクトを取得しますか?
Hardik Gajjar 2016

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が「ロケールのフルネームとしての月」を表すことに注意してください。「1月」や「12月」のように、「02」は解析されません。
2018

1
これの日付書式文字列は正しくありません。%Bでなく%mである必要があります
アナウンサー2018年

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
Jeff Bluemel

5

「24052010」のような日付文字列があり、このための日付オブジェクトが必要です。

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

このcus_dateは日付オブジェクトを提供します。

これを使用して、日付オブジェクトから日付文字列を取得できます。

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

3

arrowpythonの日付を操作するために本当に素晴らしいと呼ばれる別のライブラリがあります。

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
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.