如何从日期时间得到日期名称

如何从 Python 中的 datetime 对象获取日期名(例如,星期一、星期二、星期三、星期四、星期五、星期六和星期日) ?

例如,datetime(2019, 9, 6, 11, 33, 0)应该给我 "Friday"

153632 次浏览
import datetime
now = datetime.datetime.now()
print(now.strftime("%A"))

See the Python docs for datetime.now, datetime.strftime and more on strftime.

>>> from datetime import datetime as date
>>> date.today().strftime("%A")
'Monday'
import datetime
numdays = 7
base = datetime.date.today()
date_list = [base + datetime.timedelta(days=x) for x in range(numdays)]
date_list_with_dayname = ["%s, %s" % ((base + datetime.timedelta(days=x)).strftime("%A"),  base + datetime.timedelta(days=x)) for x in range(numdays)]

If you don't mind using another package, you can also use pandas to achieve what you want:

>>> my_date = datetime.datetime(2019, 9, 6, 11, 33, 0)
>>> pd.to_datetime(my_date).day_name()
'Friday'

It does not sound like a good idea to use another package for such easy task, the advantage of it is that day_name method seems more understandable to me than strftime("%A") (you might easily forget what is the right directive for the format to get the day name).

Hopefully, this could be added to datetime package directly one day (e.g. my_date.day_name()).

Alternative

You can use import time instead of datetime as following:

import time
WEEKDAYS = ['Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday', 'Sunday']


now = time.localtime()
weekday_index = now.tm_wday
print(WEEKDAYS[weekday_index])

import datetime import pandas as pd data['day']=data.index