Convert JSON date string to Python datetime
Solution 1:
Try the following format:
%Y-%m-%dT%H:%M:%S.%fZ
For example:
>>> datetime.datetime.strptime('2012-05-29T19:30:03.283Z', '%Y-%m-%dT%H:%M:%S.%fZ')
datetime.datetime(2012, 5, 29, 19, 30, 3, 283000)
The Z
in the date just means that it should be interpreted as a UTC time, so ignoring it won't cause any loss of information. You can find this information here: http://www.w3.org/TR/NOTE-datetime
Solution 2:
To provide an alternative, if you don't mind installing the python-dateutil
package, you can use dateutil.parser.parse
. Be advised that the format of the input is guessed by parse
; an invalid input can still be interpreted, correctly or otherwise. Guessing the format will however be significantly slower than specifying it explicitly.
Without timezone
If you would rather not have the time zone set, which is perfectly fine if you represent all times internally as UTC only, use:
>>> dateutil.parser.parse('2012-05-29T19:30:03.283Z', ignoretz=True)
datetime.datetime(2012, 5, 29, 19, 30, 3, 283000)
With timezone
Note that unlike datetime.datetime.strptime
, this default call to parse
automatically preserves the UTC time zone.
>>> import dateutil.parser
>>> dateutil.parser.parse('2012-05-29T19:30:03.283Z')
datetime.datetime(2012, 5, 29, 19, 30, 3, 283000, tzinfo=tzutc())
If a test assertion for equality needs to be made, the expected object can be constructed as:
>>> import datetime
>>> datetime.datetime(2012, 5, 29, 19, 30, 3, 283000, tzinfo=dateutil.tz.tzutc())