I have a date string with the format 'Mon Feb 15 2010'. I want to change the format to '15/02/2010'. How can I do this?
-
2Duplicate of all of these: stackoverflow.com/search?q=%5Bpython%5D+parse+date. Exact duplicate of thise: stackoverflow.com/questions/1713594/…S.Lott– S.Lott2010-02-15 11:13:51 +00:00Commented Feb 15, 2010 at 11:13
-
Does this answer your question? Converting string into datetimeAMC– AMC2020-09-18 20:31:37 +00:00Commented Sep 18, 2020 at 20:31
-
Does this answer your question? Parse a string with a date to a datetime objectPeter Mortensen– Peter Mortensen2023-10-30 13:51:36 +00:00Commented Oct 30, 2023 at 13:51
10 Answers
The datetime module could help you with that:
datetime.datetime.strptime(input_date_string, input_format).strftime(output_format)
For the specific example, you could do:
>>> from datetime import datetime
>>> datetime.strptime('Mon Feb 15 2010', '%a %b %d %Y').strftime('%d/%m/%Y')
'15/02/2010'
Learn more about different formats here.
3 Comments
format1 needs to be a string to express the input date string's format. format2 is the target string format to output.strptime and strftime are really powerful functions. It's weird I couldn't find them in the python docsYou can install the dateutil library. Its parse function can figure out what format a string is in without having to specify the format like you do with 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
4 Comments
python 3.x needs to install python-dateutil pip install python-dateutildayfirst that will be used to deferentiate between YDM and YMD dates parse docs.)Convert a string to a datetime object:
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
2 Comments
As this question comes often, here is the simple explanation.
datetime or time module has two important functions.
- strftime - creates a string representation of date or time from a datetime or time object.
- strptime - creates a datetime or time object from a string.
In both cases, we need a formating string. It is the representation that tells how the date or time is formatted in your string.
Now lets assume we have a date object.
>>> from datetime import datetime
>>> d = datetime(2010, 2, 15)
>>> d
datetime.datetime(2010, 2, 15, 0, 0)
If we want to create a string from this date in the format 'Mon Feb 15 2010'
>>> s = d.strftime('%a %b %d %y')
>>> print s
Mon Feb 15 10
Lets assume we want to convert this s again to a datetime object.
>>> new_date = datetime.strptime(s, '%a %b %d %y')
>>> print new_date
2010-02-15 00:00:00
Refer This document all formatting directives regarding datetime.
Comments
@codeling and @user1767754 : The following two lines will work. I saw no one posted the complete solution for the example problem that was asked. Hopefully this is enough explanation.
import datetime
x = datetime.datetime.strptime("Mon Feb 15 2010", "%a %b %d %Y").strftime("%d/%m/%Y")
print(x)
Output:
15/02/2010
Comments
You may achieve this using pandas as well:
import pandas as pd
pd.to_datetime('Mon Feb 15 2010', format='%a %b %d %Y').strftime('%d/%m/%Y')
Output:
'15/02/2010'
You may apply pandas approach for different datatypes as:
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)
Output:
15/02/2010
['15/02/2010' '17/02/2010']
['15/02/2010' '17/02/2010']
['15/02/2010' '17/02/2010']
Comments
Just for the sake of completion: when parsing a date using strptime() and the date contains the name of a day, month, etc, be aware that you have to account for the locale.
It's mentioned as a footnote in the docs as well.
As an example:
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'
Comments
Use the strptime() and strftime() functions in the datetime library.
https://docs.python.org/3/library/datetime.html#strftime-strptime-behavior
Examples: 3. Dates and Times