Python3.7 Convert comma delimited datetime [duplicate] - python
This is my code:
import datetime
today = datetime.date.today()
print(today)
This prints: 2008-11-22 which is exactly what I want.
But, I have a list I'm appending this to and then suddenly everything goes "wonky". Here is the code:
import datetime
mylist = []
today = datetime.date.today()
mylist.append(today)
print(mylist)
This prints the following:
[datetime.date(2008, 11, 22)]
How can I get just a simple date like 2008-11-22?
The WHY: dates are objects
In Python, dates are objects. Therefore, when you manipulate them, you manipulate objects, not strings or timestamps.
Any object in Python has TWO string representations:
The regular representation that is used by print can be get using the str() function. It is most of the time the most common human readable format and is used to ease display. So str(datetime.datetime(2008, 11, 22, 19, 53, 42)) gives you '2008-11-22 19:53:42'.
The alternative representation that is used to represent the object nature (as a data). It can be get using the repr() function and is handy to know what kind of data your manipulating while you are developing or debugging. repr(datetime.datetime(2008, 11, 22, 19, 53, 42)) gives you 'datetime.datetime(2008, 11, 22, 19, 53, 42)'.
What happened is that when you have printed the date using print, it used str() so you could see a nice date string. But when you have printed mylist, you have printed a list of objects and Python tried to represent the set of data, using repr().
The How: what do you want to do with that?
Well, when you manipulate dates, keep using the date objects all long the way. They got thousand of useful methods and most of the Python API expect dates to be objects.
When you want to display them, just use str(). In Python, the good practice is to explicitly cast everything. So just when it's time to print, get a string representation of your date using str(date).
One last thing. When you tried to print the dates, you printed mylist. If you want to print a date, you must print the date objects, not their container (the list).
E.G, you want to print all the date in a list :
for date in mylist :
print str(date)
Note that in that specific case, you can even omit str() because print will use it for you. But it should not become a habit :-)
Practical case, using your code
import datetime
mylist = []
today = datetime.date.today()
mylist.append(today)
print mylist[0] # print the date object, not the container ;-)
2008-11-22
# It's better to always use str() because :
print "This is a new day : ", mylist[0] # will work
>>> This is a new day : 2008-11-22
print "This is a new day : " + mylist[0] # will crash
>>> cannot concatenate 'str' and 'datetime.date' objects
print "This is a new day : " + str(mylist[0])
>>> This is a new day : 2008-11-22
Advanced date formatting
Dates have a default representation, but you may want to print them in a specific format. In that case, you can get a custom string representation using the strftime() method.
strftime() expects a string pattern explaining how you want to format your date.
E.G :
print today.strftime('We are the %d, %b %Y')
>>> 'We are the 22, Nov 2008'
All the letter after a "%" represent a format for something:
%d is the day number (2 digits, prefixed with leading zero's if necessary)
%m is the month number (2 digits, prefixed with leading zero's if necessary)
%b is the month abbreviation (3 letters)
%B is the month name in full (letters)
%y is the year number abbreviated (last 2 digits)
%Y is the year number full (4 digits)
etc.
Have a look at the official documentation, or McCutchen's quick reference you can't know them all.
Since PEP3101, every object can have its own format used automatically by the method format of any string. In the case of the datetime, the format is the same used in
strftime. So you can do the same as above like this:
print "We are the {:%d, %b %Y}".format(today)
>>> 'We are the 22, Nov 2008'
The advantage of this form is that you can also convert other objects at the same time.
With the introduction of Formatted string literals (since Python 3.6, 2016-12-23) this can be written as
import datetime
f"{datetime.datetime.now():%Y-%m-%d}"
>>> '2017-06-15'
Localization
Dates can automatically adapt to the local language and culture if you use them the right way, but it's a bit complicated. Maybe for another question on SO(Stack Overflow) ;-)
import datetime
print datetime.datetime.now().strftime("%Y-%m-%d %H:%M")
Edit:
After Cees' suggestion, I have started using time as well:
import time
print time.strftime("%Y-%m-%d %H:%M")
The date, datetime, and time objects all support a strftime(format) method,
to create a string representing the time under the control of an explicit format
string.
Here is a list of the format codes with their directive and meaning.
%a Locale’s abbreviated weekday name.
%A Locale’s full weekday name.
%b Locale’s abbreviated month name.
%B Locale’s full month name.
%c Locale’s appropriate date and time representation.
%d Day of the month as a decimal number [01,31].
%f Microsecond as a decimal number [0,999999], zero-padded on the left
%H Hour (24-hour clock) as a decimal number [00,23].
%I Hour (12-hour clock) as a decimal number [01,12].
%j Day of the year as a decimal number [001,366].
%m Month as a decimal number [01,12].
%M Minute as a decimal number [00,59].
%p Locale’s equivalent of either AM or PM.
%S Second as a decimal number [00,61].
%U Week number of the year (Sunday as the first day of the week)
%w Weekday as a decimal number [0(Sunday),6].
%W Week number of the year (Monday as the first day of the week)
%x Locale’s appropriate date representation.
%X Locale’s appropriate time representation.
%y Year without century as a decimal number [00,99].
%Y Year with century as a decimal number.
%z UTC offset in the form +HHMM or -HHMM.
%Z Time zone name (empty string if the object is naive).
%% A literal '%' character.
This is what we can do with the datetime and time modules in Python
import time
import datetime
print "Time in seconds since the epoch: %s" %time.time()
print "Current date and time: ", datetime.datetime.now()
print "Or like this: ", datetime.datetime.now().strftime("%y-%m-%d-%H-%M")
print "Current year: ", datetime.date.today().strftime("%Y")
print "Month of year: ", datetime.date.today().strftime("%B")
print "Week number of the year: ", datetime.date.today().strftime("%W")
print "Weekday of the week: ", datetime.date.today().strftime("%w")
print "Day of year: ", datetime.date.today().strftime("%j")
print "Day of the month : ", datetime.date.today().strftime("%d")
print "Day of week: ", datetime.date.today().strftime("%A")
That will print out something like this:
Time in seconds since the epoch: 1349271346.46
Current date and time: 2012-10-03 15:35:46.461491
Or like this: 12-10-03-15-35
Current year: 2012
Month of year: October
Week number of the year: 40
Weekday of the week: 3
Day of year: 277
Day of the month : 03
Day of week: Wednesday
Use date.strftime. The formatting arguments are described in the documentation.
This one is what you wanted:
some_date.strftime('%Y-%m-%d')
This one takes Locale into account. (do this)
some_date.strftime('%c')
This is shorter:
>>> import time
>>> time.strftime("%Y-%m-%d %H:%M")
'2013-11-19 09:38'
# convert date time to regular format.
d_date = datetime.datetime.now()
reg_format_date = d_date.strftime("%Y-%m-%d %I:%M:%S %p")
print(reg_format_date)
# some other date formats.
reg_format_date = d_date.strftime("%d %B %Y %I:%M:%S %p")
print(reg_format_date)
reg_format_date = d_date.strftime("%Y-%m-%d %H:%M:%S")
print(reg_format_date)
OUTPUT
2016-10-06 01:21:34 PM
06 October 2016 01:21:34 PM
2016-10-06 13:21:34
Or even
from datetime import datetime, date
"{:%d.%m.%Y}".format(datetime.now())
Out: '25.12.2013
or
"{} - {:%d.%m.%Y}".format("Today", datetime.now())
Out: 'Today - 25.12.2013'
"{:%A}".format(date.today())
Out: 'Wednesday'
'{}__{:%Y.%m.%d__%H-%M}.log'.format(__name__, datetime.now())
Out: '__main____2014.06.09__16-56.log'
Simple answer -
datetime.date.today().isoformat()
With type-specific datetime string formatting (see nk9's answer using str.format().) in a Formatted string literal (since Python 3.6, 2016-12-23):
>>> import datetime
>>> f"{datetime.datetime.now():%Y-%m-%d}"
'2017-06-15'
The date/time format directives are not documented as part of the Format String Syntax but rather in date, datetime, and time's strftime() documentation. The are based on the 1989 C Standard, but include some ISO 8601 directives since Python 3.6.
I hate the idea of importing too many modules for convenience. I would rather work with available module which in this case is datetime rather than calling a new module time.
>>> a = datetime.datetime(2015, 04, 01, 11, 23, 22)
>>> a.strftime('%Y-%m-%d %H:%M')
'2015-04-01 11:23'
You need to convert the datetime object to a str.
The following code worked for me:
import datetime
collection = []
dateTimeString = str(datetime.date.today())
collection.append(dateTimeString)
print(collection)
Let me know if you need any more help.
In Python you can format a datetime using the strftime() method from the date, time and datetime classes in the datetime module.
In your specific case, you are using the date class from datetime. You can use the following snippet to format the today variable into a string with the format yyyy-MM-dd:
import datetime
today = datetime.date.today()
print("formatted datetime: %s" % today.strftime("%Y-%m-%d"))
In the following a more complete example:
import datetime
today = datetime.date.today()
# datetime in d/m/Y H:M:S format
date_time = today.strftime("%d/%m/%Y, %H:%M:%S")
print("datetime: %s" % date_time)
# datetime in Y-m-d H:M:S format
date_time = today.strftime("%Y-%m-%d, %H:%M:%S")
print("datetime: %s" % date_time)
# format date
date = today.strftime("%d/%m/%Y")
print("date: %s" % time)
# format time
time = today.strftime("%H:%M:%S")
print("time: %s" % time)
# day
day = today.strftime("%d")
print("day: %s" % day)
# month
month = today.strftime("%m")
print("month: %s" % month)
# year
year = today.strftime("%Y")
print("year: %s" % year)
More directives:
Sources:
Format DateTime in Python
strftime
You can do:
mylist.append(str(today))
Considering the fact you asked for something simple to do what you wanted, you could just:
import datetime
str(datetime.date.today())
For those wanting locale-based date and not including time, use:
>>> some_date.strftime('%x')
07/11/2019
Since the print today returns what you want this means that the today object's __str__ function returns the string you are looking for.
So you can do mylist.append(today.__str__()) as well.
from datetime import date
def today_in_str_format():
return str(date.today())
print (today_in_str_format())
This will print 2018-06-23 if that's what you want :)
You may want to append it as a string?
import datetime
mylist = []
today = str(datetime.date.today())
mylist.append(today)
print(mylist)
For pandas.Timestamps, strftime() can be used e.g.:
utc_now = datetime.now()
For isoformat:
utc_now.isoformat()
For any format e.g.:
utc_now.strftime("%m/%d/%Y, %H:%M:%S")
You can use easy_date to make it easy:
import date_converter
my_date = date_converter.date_to_string(today, '%Y-%m-%d')
A quick disclaimer for my answer - I've only been learning Python for about 2 weeks, so I am by no means an expert; therefore, my explanation may not be the best and I may use incorrect terminology. Anyway, here it goes.
I noticed in your code that when you declared your variable today = datetime.date.today() you chose to name your variable with the name of a built-in function.
When your next line of code mylist.append(today) appended your list, it appended the entire string datetime.date.today(), which you had previously set as the value of your today variable, rather than just appending today().
A simple solution, albeit maybe not one most coders would use when working with the datetime module, is to change the name of your variable.
Here's what I tried:
import datetime
mylist = []
present = datetime.date.today()
mylist.append(present)
print present
and it prints yyyy-mm-dd.
Here is how to display the date as (year/month/day) :
from datetime import datetime
now = datetime.now()
print '%s/%s/%s' % (now.year, now.month, now.day)
import datetime
import time
months = ["Unknown","January","Febuary","Marchh","April","May","June","July","August","September","October","November","December"]
datetimeWrite = (time.strftime("%d-%m-%Y "))
date = time.strftime("%d")
month= time.strftime("%m")
choices = {'01': 'Jan', '02':'Feb','03':'Mar','04':'Apr','05':'May','06': 'Jun','07':'Jul','08':'Aug','09':'Sep','10':'Oct','11':'Nov','12':'Dec'}
result = choices.get(month, 'default')
year = time.strftime("%Y")
Date = date+"-"+result+"-"+year
print Date
In this way you can get Date formatted like this example: 22-Jun-2017
I don't fully understand but, can use pandas for getting times in right format:
>>> import pandas as pd
>>> pd.to_datetime('now')
Timestamp('2018-10-07 06:03:30')
>>> print(pd.to_datetime('now'))
2018-10-07 06:03:47
>>> pd.to_datetime('now').date()
datetime.date(2018, 10, 7)
>>> print(pd.to_datetime('now').date())
2018-10-07
>>>
And:
>>> l=[]
>>> l.append(pd.to_datetime('now').date())
>>> l
[datetime.date(2018, 10, 7)]
>>> map(str,l)
<map object at 0x0000005F67CCDF98>
>>> list(map(str,l))
['2018-10-07']
But it's storing strings but easy to convert:
>>> l=list(map(str,l))
>>> list(map(pd.to_datetime,l))
[Timestamp('2018-10-07 00:00:00')]
maybe the shortest solution, which exactly matches your situation, would be:
mylist.append(str(AnyDate)[:10])
or even shorter, e.g.:
f'{AnyDate}'[:10]
PS: it doesn't need to be today.
Related
Use current month/day in datetime parse
I'm trying to parse a string that is just '07:43 PM'. I figured out the strptime() function but when I print the result the day, month and year are all wrong. It's not using the current time, it uses 1, 1 and 1900 respectively. A naive solution to this I found would be to just use .replace() and replace the day, month and year with the current values. Is there something else I can do? y = '07:43 PM' print(datetime.strptime(y, '%I:%M %p')) #1900-01-01 19:43:00
As the comment said you can get the now time then update those fields with what you want such as: from datetime import datetime y = '07:43 PM' now, stripped = datetime.now(), datetime.strptime(y, '%I:%M %p') now = now.replace(hour=stripped.hour, minute=stripped.minute) print(now)
print a datetime and a rounded float in a tuple without function name, quotations or parenthesis in the most pythonic way [duplicate]
This is my code: import datetime today = datetime.date.today() print(today) This prints: 2008-11-22 which is exactly what I want. But, I have a list I'm appending this to and then suddenly everything goes "wonky". Here is the code: import datetime mylist = [] today = datetime.date.today() mylist.append(today) print(mylist) This prints the following: [datetime.date(2008, 11, 22)] How can I get just a simple date like 2008-11-22?
The WHY: dates are objects In Python, dates are objects. Therefore, when you manipulate them, you manipulate objects, not strings or timestamps. Any object in Python has TWO string representations: The regular representation that is used by print can be get using the str() function. It is most of the time the most common human readable format and is used to ease display. So str(datetime.datetime(2008, 11, 22, 19, 53, 42)) gives you '2008-11-22 19:53:42'. The alternative representation that is used to represent the object nature (as a data). It can be get using the repr() function and is handy to know what kind of data your manipulating while you are developing or debugging. repr(datetime.datetime(2008, 11, 22, 19, 53, 42)) gives you 'datetime.datetime(2008, 11, 22, 19, 53, 42)'. What happened is that when you have printed the date using print, it used str() so you could see a nice date string. But when you have printed mylist, you have printed a list of objects and Python tried to represent the set of data, using repr(). The How: what do you want to do with that? Well, when you manipulate dates, keep using the date objects all long the way. They got thousand of useful methods and most of the Python API expect dates to be objects. When you want to display them, just use str(). In Python, the good practice is to explicitly cast everything. So just when it's time to print, get a string representation of your date using str(date). One last thing. When you tried to print the dates, you printed mylist. If you want to print a date, you must print the date objects, not their container (the list). E.G, you want to print all the date in a list : for date in mylist : print str(date) Note that in that specific case, you can even omit str() because print will use it for you. But it should not become a habit :-) Practical case, using your code import datetime mylist = [] today = datetime.date.today() mylist.append(today) print mylist[0] # print the date object, not the container ;-) 2008-11-22 # It's better to always use str() because : print "This is a new day : ", mylist[0] # will work >>> This is a new day : 2008-11-22 print "This is a new day : " + mylist[0] # will crash >>> cannot concatenate 'str' and 'datetime.date' objects print "This is a new day : " + str(mylist[0]) >>> This is a new day : 2008-11-22 Advanced date formatting Dates have a default representation, but you may want to print them in a specific format. In that case, you can get a custom string representation using the strftime() method. strftime() expects a string pattern explaining how you want to format your date. E.G : print today.strftime('We are the %d, %b %Y') >>> 'We are the 22, Nov 2008' All the letter after a "%" represent a format for something: %d is the day number (2 digits, prefixed with leading zero's if necessary) %m is the month number (2 digits, prefixed with leading zero's if necessary) %b is the month abbreviation (3 letters) %B is the month name in full (letters) %y is the year number abbreviated (last 2 digits) %Y is the year number full (4 digits) etc. Have a look at the official documentation, or McCutchen's quick reference you can't know them all. Since PEP3101, every object can have its own format used automatically by the method format of any string. In the case of the datetime, the format is the same used in strftime. So you can do the same as above like this: print "We are the {:%d, %b %Y}".format(today) >>> 'We are the 22, Nov 2008' The advantage of this form is that you can also convert other objects at the same time. With the introduction of Formatted string literals (since Python 3.6, 2016-12-23) this can be written as import datetime f"{datetime.datetime.now():%Y-%m-%d}" >>> '2017-06-15' Localization Dates can automatically adapt to the local language and culture if you use them the right way, but it's a bit complicated. Maybe for another question on SO(Stack Overflow) ;-)
import datetime print datetime.datetime.now().strftime("%Y-%m-%d %H:%M") Edit: After Cees' suggestion, I have started using time as well: import time print time.strftime("%Y-%m-%d %H:%M")
The date, datetime, and time objects all support a strftime(format) method, to create a string representing the time under the control of an explicit format string. Here is a list of the format codes with their directive and meaning. %a Locale’s abbreviated weekday name. %A Locale’s full weekday name. %b Locale’s abbreviated month name. %B Locale’s full month name. %c Locale’s appropriate date and time representation. %d Day of the month as a decimal number [01,31]. %f Microsecond as a decimal number [0,999999], zero-padded on the left %H Hour (24-hour clock) as a decimal number [00,23]. %I Hour (12-hour clock) as a decimal number [01,12]. %j Day of the year as a decimal number [001,366]. %m Month as a decimal number [01,12]. %M Minute as a decimal number [00,59]. %p Locale’s equivalent of either AM or PM. %S Second as a decimal number [00,61]. %U Week number of the year (Sunday as the first day of the week) %w Weekday as a decimal number [0(Sunday),6]. %W Week number of the year (Monday as the first day of the week) %x Locale’s appropriate date representation. %X Locale’s appropriate time representation. %y Year without century as a decimal number [00,99]. %Y Year with century as a decimal number. %z UTC offset in the form +HHMM or -HHMM. %Z Time zone name (empty string if the object is naive). %% A literal '%' character. This is what we can do with the datetime and time modules in Python import time import datetime print "Time in seconds since the epoch: %s" %time.time() print "Current date and time: ", datetime.datetime.now() print "Or like this: ", datetime.datetime.now().strftime("%y-%m-%d-%H-%M") print "Current year: ", datetime.date.today().strftime("%Y") print "Month of year: ", datetime.date.today().strftime("%B") print "Week number of the year: ", datetime.date.today().strftime("%W") print "Weekday of the week: ", datetime.date.today().strftime("%w") print "Day of year: ", datetime.date.today().strftime("%j") print "Day of the month : ", datetime.date.today().strftime("%d") print "Day of week: ", datetime.date.today().strftime("%A") That will print out something like this: Time in seconds since the epoch: 1349271346.46 Current date and time: 2012-10-03 15:35:46.461491 Or like this: 12-10-03-15-35 Current year: 2012 Month of year: October Week number of the year: 40 Weekday of the week: 3 Day of year: 277 Day of the month : 03 Day of week: Wednesday
Use date.strftime. The formatting arguments are described in the documentation. This one is what you wanted: some_date.strftime('%Y-%m-%d') This one takes Locale into account. (do this) some_date.strftime('%c')
This is shorter: >>> import time >>> time.strftime("%Y-%m-%d %H:%M") '2013-11-19 09:38'
# convert date time to regular format. d_date = datetime.datetime.now() reg_format_date = d_date.strftime("%Y-%m-%d %I:%M:%S %p") print(reg_format_date) # some other date formats. reg_format_date = d_date.strftime("%d %B %Y %I:%M:%S %p") print(reg_format_date) reg_format_date = d_date.strftime("%Y-%m-%d %H:%M:%S") print(reg_format_date) OUTPUT 2016-10-06 01:21:34 PM 06 October 2016 01:21:34 PM 2016-10-06 13:21:34
Or even from datetime import datetime, date "{:%d.%m.%Y}".format(datetime.now()) Out: '25.12.2013 or "{} - {:%d.%m.%Y}".format("Today", datetime.now()) Out: 'Today - 25.12.2013' "{:%A}".format(date.today()) Out: 'Wednesday' '{}__{:%Y.%m.%d__%H-%M}.log'.format(__name__, datetime.now()) Out: '__main____2014.06.09__16-56.log'
Simple answer - datetime.date.today().isoformat()
With type-specific datetime string formatting (see nk9's answer using str.format().) in a Formatted string literal (since Python 3.6, 2016-12-23): >>> import datetime >>> f"{datetime.datetime.now():%Y-%m-%d}" '2017-06-15' The date/time format directives are not documented as part of the Format String Syntax but rather in date, datetime, and time's strftime() documentation. The are based on the 1989 C Standard, but include some ISO 8601 directives since Python 3.6.
I hate the idea of importing too many modules for convenience. I would rather work with available module which in this case is datetime rather than calling a new module time. >>> a = datetime.datetime(2015, 04, 01, 11, 23, 22) >>> a.strftime('%Y-%m-%d %H:%M') '2015-04-01 11:23'
You need to convert the datetime object to a str. The following code worked for me: import datetime collection = [] dateTimeString = str(datetime.date.today()) collection.append(dateTimeString) print(collection) Let me know if you need any more help.
In Python you can format a datetime using the strftime() method from the date, time and datetime classes in the datetime module. In your specific case, you are using the date class from datetime. You can use the following snippet to format the today variable into a string with the format yyyy-MM-dd: import datetime today = datetime.date.today() print("formatted datetime: %s" % today.strftime("%Y-%m-%d")) In the following a more complete example: import datetime today = datetime.date.today() # datetime in d/m/Y H:M:S format date_time = today.strftime("%d/%m/%Y, %H:%M:%S") print("datetime: %s" % date_time) # datetime in Y-m-d H:M:S format date_time = today.strftime("%Y-%m-%d, %H:%M:%S") print("datetime: %s" % date_time) # format date date = today.strftime("%d/%m/%Y") print("date: %s" % time) # format time time = today.strftime("%H:%M:%S") print("time: %s" % time) # day day = today.strftime("%d") print("day: %s" % day) # month month = today.strftime("%m") print("month: %s" % month) # year year = today.strftime("%Y") print("year: %s" % year) More directives: Sources: Format DateTime in Python strftime
You can do: mylist.append(str(today))
Considering the fact you asked for something simple to do what you wanted, you could just: import datetime str(datetime.date.today())
For those wanting locale-based date and not including time, use: >>> some_date.strftime('%x') 07/11/2019
Since the print today returns what you want this means that the today object's __str__ function returns the string you are looking for. So you can do mylist.append(today.__str__()) as well.
from datetime import date def today_in_str_format(): return str(date.today()) print (today_in_str_format()) This will print 2018-06-23 if that's what you want :)
You may want to append it as a string? import datetime mylist = [] today = str(datetime.date.today()) mylist.append(today) print(mylist)
For pandas.Timestamps, strftime() can be used e.g.: utc_now = datetime.now() For isoformat: utc_now.isoformat() For any format e.g.: utc_now.strftime("%m/%d/%Y, %H:%M:%S")
You can use easy_date to make it easy: import date_converter my_date = date_converter.date_to_string(today, '%Y-%m-%d')
A quick disclaimer for my answer - I've only been learning Python for about 2 weeks, so I am by no means an expert; therefore, my explanation may not be the best and I may use incorrect terminology. Anyway, here it goes. I noticed in your code that when you declared your variable today = datetime.date.today() you chose to name your variable with the name of a built-in function. When your next line of code mylist.append(today) appended your list, it appended the entire string datetime.date.today(), which you had previously set as the value of your today variable, rather than just appending today(). A simple solution, albeit maybe not one most coders would use when working with the datetime module, is to change the name of your variable. Here's what I tried: import datetime mylist = [] present = datetime.date.today() mylist.append(present) print present and it prints yyyy-mm-dd.
Here is how to display the date as (year/month/day) : from datetime import datetime now = datetime.now() print '%s/%s/%s' % (now.year, now.month, now.day)
import datetime import time months = ["Unknown","January","Febuary","Marchh","April","May","June","July","August","September","October","November","December"] datetimeWrite = (time.strftime("%d-%m-%Y ")) date = time.strftime("%d") month= time.strftime("%m") choices = {'01': 'Jan', '02':'Feb','03':'Mar','04':'Apr','05':'May','06': 'Jun','07':'Jul','08':'Aug','09':'Sep','10':'Oct','11':'Nov','12':'Dec'} result = choices.get(month, 'default') year = time.strftime("%Y") Date = date+"-"+result+"-"+year print Date In this way you can get Date formatted like this example: 22-Jun-2017
I don't fully understand but, can use pandas for getting times in right format: >>> import pandas as pd >>> pd.to_datetime('now') Timestamp('2018-10-07 06:03:30') >>> print(pd.to_datetime('now')) 2018-10-07 06:03:47 >>> pd.to_datetime('now').date() datetime.date(2018, 10, 7) >>> print(pd.to_datetime('now').date()) 2018-10-07 >>> And: >>> l=[] >>> l.append(pd.to_datetime('now').date()) >>> l [datetime.date(2018, 10, 7)] >>> map(str,l) <map object at 0x0000005F67CCDF98> >>> list(map(str,l)) ['2018-10-07'] But it's storing strings but easy to convert: >>> l=list(map(str,l)) >>> list(map(pd.to_datetime,l)) [Timestamp('2018-10-07 00:00:00')]
maybe the shortest solution, which exactly matches your situation, would be: mylist.append(str(AnyDate)[:10]) or even shorter, e.g.: f'{AnyDate}'[:10] PS: it doesn't need to be today.
How can I convert text to DateTime?
I scraped a website and got the following Output: 2018-06-07T12:22:00+0200 2018-06-07T12:53:00+0200 2018-06-07T13:22:00+0200 Is there a way I can take the first one and convert it into a DateTime value?
Just parse the string into year, month, day, hour and minute integers and then create a new date time object with those variables. Check out the datetime docs
You can convert string format of datetime to datetime object like this using strptime, here %z is the time zone : import datetime dt = "2018-06-07T12:22:00+0200" ndt = datetime.datetime.strptime(dt, "%Y-%m-%dT%H:%M:%S%z") # output 2018-06-07 12:22:00+02:00
The following function (not mine) should help you with what you want: df['date_column'] = pd.to_datetime(df['date_column'], format = '%d/%m/%Y %H:%M').dt.strftime('%Y%V') You can mess around with the keys next to the % symbols to achieve what you want. You may, however, need to do some light cleaning of your values before you can use them with this function, i.e. replacing 2018-06-07T12:22:00+0200 with 2018-06-07 12:22.
You can use datetime lib. from datetime import datetime datetime_object = datetime.strptime('Jun 1 2005 1:33PM', '%b %d %Y %I:%M%p') datetime.strptime documentation Solution here
String to date formatting
I have a string of the following format: x = '2018-02-15-11' I need to convert this to a date format. I have tried: from datetime import date from datetime import time from datetime import datetime dhs = '2018-02-15-11' x = datetime.strptime(dhs, '%Y-%M-%d-%H') print x However, the output is 2018-01-15 11:02:00 I need the output in the format (as date object): 2018-01-15-11 Am I missing something here?
I think there could be a mistake on your part, you have used %Y-%M-%d-%H where %M indicates minutes, not month. But according to the look, it should be %m i.e. month. Answering your original question, the format specifiers for strftime (datetime to string) and strptime (string to datetime) are the same. So you can use datetime.datetime.strftime('%Y-%m-%d-%H') like: In [47]: dhs = '2018-02-15-11' ...: x = datetime.datetime.strptime(dhs, '%Y-%m-%d-%H') ...: print(x.strftime('%Y-%m-%d-%H')) ...: 2018-02-15-11 I've used %m instead of %M here. If you are really sure about this, use %M if you want. N.B: You are getting same string you've started with.
how to convert date string(2016/5/7/ 4:25:00 PM) to date format to (2016-05-07 4:25:00) in python [duplicate]
This question already has answers here: How to print a date in a regular format? (25 answers) Closed 6 years ago. having trouble converting this string into a datetime this is what I tried so far in code: import datetime mystring = '2016/5/7/ 4:25:00 PM' dateobj = datetime.datetime.strptime(mystring, "%Y-%B-%dT%H:%M:%S-%H:%M") print (dateobj) it throws me errors and I search in the library and still can't figure it out what I have wrong in my format. Please any help I'll gratly apreciate it
You can do it as: import datetime mystring = '2016/5/7 4:25:00 PM' dateobj = datetime.datetime.strptime(mystring, "%Y/%m/%d %I:%M:%S %p") dateobj Out[1]: datetime.datetime(2016, 5, 7, 16, 25) dateobj1 = datetime.datetime.strptime(mystring, "%Y/%m/%d %I:%M:%S %p").strftime("%Y-%m-%d %I:%M:%S") dateobj1 Out[2]: '2016-05-07 04:25:00'
The issue you are having is that in order to convert a date object you first have to create a date object. This means that your formatting will have to match the current string format '2016/5/7 4:25:00 PM' = "%Y/%m/%d %H:%M:%S %p". So we can now create a date obj and then format it using strftime with your new format "%Y-%B-%dT%H:%M:%S-%H:%M". import datetime mystring = '2016/5/7 4:25:00 PM' dateobj = datetime.datetime.strptime(mystring, "%Y/%m/%d %H:%M:%S %p") dateobj = datetime.datetime.strftime(dateobj, "%Y-%B-%dT%H:%M:%S-%H:%M") print (dateobj) the output recieved is a little funky, but it matches your format perfectly. Visit the datetime library to view the format codes and read up on strptime vs strftime. Good luck. Output: 2016-May-07T04:25:00-04:25
I'm not sure where your format string came from, but it's wrong. It doesn't match your string format at all. Take a look at the available options in the documentation. You want this: dateobj = datetime.datetime.strptime(mystring, "%Y/%m/%d/ %I:%M:%S %p") This will get you a date object. You can then do this to reformat it how you want: dateobj.strftime("%Y-%m-%d %I:%M:%S") A couple things that were wrong with yours: You used %H twice. This resulted in an error saying it'd be redefined. %B is full month name (ie. January). You have a numeral. The -s are incorrect since you have /s. The T is not in your string at all.
Easily with dateutil.parser.parse >>> from dateutil.parser import parse >>> d = parse('2016/5/7/ 4:25:00 PM') >>> d.strftime("%Y-%B-%dT%H:%M:%S-%H:%M") '2016-May-07T16:25:00-16:25' >>> d.strftime("%Y-%m-%d %I:%M:%S") '2016-05-07 04:25:00'