niklasfi
niklasfi

Reputation: 15931

How do I convert a datetime to date?

How do I convert a datetime.datetime object (e.g., the return value of datetime.datetime.now()) to a datetime.date object in Python?

Upvotes: 1043

Views: 1364814

Answers (10)

Orn Arnar
Orn Arnar

Reputation: 131

If you are using pandas then this can solve your problem:

Lets say that you have a variable called start_time of type datetime64 in your dataframe then you can get the date part like this:

df.start_time.dt.date

Upvotes: -4

Manjula Devi
Manjula Devi

Reputation: 149

Solved: AttributeError: 'Series' object has no attribute 'date'

You can use as below,

df["date"] = pd.to_datetime(df["date"]).dt.date

where in above code date contains both date and time (2020-09-21 22:32:00), using above code we can get only date as (2020-09-21)

Upvotes: 0

Wei Chun Chang
Wei Chun Chang

Reputation: 45

I use data.strftime('%y-%m-%d') with lambda to transfer column to date

Upvotes: 2

ars
ars

Reputation: 123498

Use the date() method:

datetime.datetime.now().date()

Upvotes: 1591

Tms91
Tms91

Reputation: 4164

Answer updated to Python 3.7 and more

Here is how you can turn a date-and-time object

(aka datetime.datetime object, the one that is stored inside models.DateTimeField django model field)

into a date object (aka datetime.date object):

from datetime import datetime

#your date-and-time object
# let's supposed it is defined as
datetime_element = datetime(2020, 7, 10, 12, 56, 54, 324893)

# where
# datetime_element = datetime(year, month, day, hour, minute, second, milliseconds)

# WHAT YOU WANT: your date-only object
date_element = datetime_element.date()

And just to be clear, if you print those elements, here is the output :

print(datetime_element)

2020-07-10 12:56:54.324893


print(date_element)

2020-07-10

Upvotes: 13

kamran26
kamran26

Reputation: 129

you could enter this code form for (today date & Names of the Day & hour) : datetime.datetime.now().strftime('%y-%m-%d %a %H:%M:%S')

'19-09-09 Mon 17:37:56'

and enter this code for (today date simply): datetime.date.today().strftime('%y-%m-%d') '19-09-10'

for object : datetime.datetime.now().date() datetime.datetime.today().date() datetime.datetime.utcnow().date() datetime.datetime.today().time() datetime.datetime.utcnow().date() datetime.datetime.utcnow().time()

Upvotes: 12

Serenity
Serenity

Reputation: 36635

import time
import datetime

# use mktime to step by one day
# end - the last day, numdays - count of days to step back
def gen_dates_list(end, numdays):
  start = end - datetime.timedelta(days=numdays+1)
  end   = int(time.mktime(end.timetuple()))
  start = int(time.mktime(start.timetuple()))
  # 86400 s = 1 day
  return xrange(start, end, 86400)

# if you need reverse the list of dates
for dt in reversed(gen_dates_list(datetime.datetime.today(), 100)):
    print datetime.datetime.fromtimestamp(dt).date()

Upvotes: 6

user395760
user395760

Reputation:

From the documentation:

datetime.datetime.date()

Return date object with same year, month and day.

Upvotes: 173

Furbeenator
Furbeenator

Reputation: 8285

You can convert a datetime object to a date with the date() method of the date time object, as follows:

<datetime_object>.date()

Upvotes: 66

tzot
tzot

Reputation: 95921

You use the datetime.datetime.date() method:

datetime.datetime.now().date()

Obviously, the expression above can (and should IMHO :) be written as:

datetime.date.today()

Upvotes: 79

Related Questions