如何在给定日期的情况下获取星期几?

899

我想要找到以下内容: 给定一个日期(datetime 对象),对应的星期几是什么?

例如,星期天是第一天,星期一是第二天……以此类推。

如果输入是今天的日期,该怎么办。

示例

>>> today = datetime.datetime(2017, 10, 20)
>>> today.get_weekday()  # what I look for

输出可能为6(因为今天是星期五)

31个回答

1378

使用 weekday()

>>> import datetime
>>> datetime.datetime.today()
datetime.datetime(2012, 3, 23, 23, 24, 55, 173504)
>>> datetime.datetime.today().weekday()
4

根据文档

返回星期几的数字,其中星期一为0,星期日为6。


502
一个重要的事情需要注意,就是在JavaScript中0 = 星期日,而Python从0开始等于星期一。这是我在前端和后端开发中遇到的问题。 - radtek
24
如果你希望把星期日设为第0天:int(datetime.datetime.today().strftime('%w')) - mrooney
49
使用 isoweekday 替换 weekday 可以从1开始计算,其中 1 表示星期一。请注意,翻译后的内容不能改变原意,应保持准确性和简洁性。 - Aman Kumar
29
使用.strftime('%A')[链接]获取星期几名称。 - rborodinov
10
请使用isoweekday()代替.weekday()。 - xjlin0
显示剩余2条评论

394

5
这似乎是生成英文星期几日期的最佳答案。我猜测它没有更多的赞,只是因为该答案已经存在大约一个月了,而问题则已存在大约三年了。 - Johnny Utahh
79
我觉得直接使用 my_date.strftime('%A') 更为有效。 - Nathan Tew
@NathanTew 1)“my_date”是一个变量吗?2)这能用于查询/聚合吗?我想计算星期一/星期二/星期三点餐的平均数量。每个订单都在新行上,就像这个问题一样,工作日必须从我们刚刚上传到elasticsearch的csv文件的日期时间列中检索。 - Cornelis

235

115

14
因为该提问涉及到一个datetime对象(而不是一个date对象),我想提一下datetime类也拥有相同的weekday()isoweekday() 方法。 - Jens

55

我为 CodeChef 的一个问题找到了解决方法。

import datetime
dt = '21/03/2012'
day, month, year = (int(x) for x in dt.split('/'))    
ans = datetime.date(year, month, day)
print (ans.strftime("%A"))

36

一个在1700/1/1之后的日期无需导入任何模块即可解决的方法

def weekDay(year, month, day):
    offset = [0, 31, 59, 90, 120, 151, 181, 212, 243, 273, 304, 334]
    week   = ['Sunday', 
              'Monday', 
              'Tuesday', 
              'Wednesday', 
              'Thursday',  
              'Friday', 
              'Saturday']
    afterFeb = 1
    if month > 2: afterFeb = 0
    aux = year - 1700 - afterFeb
    # dayOfWeek for 1700/1/1 = 5, Friday
    dayOfWeek  = 5
    # partial sum of days betweem current date and 1700/1/1
    dayOfWeek += (aux + afterFeb) * 365                  
    # leap year correction    
    dayOfWeek += aux / 4 - aux / 100 + (aux + 100) / 400     
    # sum monthly and day offsets
    dayOfWeek += offset[month - 1] + (day - 1)               
    dayOfWeek %= 7
    return dayOfWeek, week[dayOfWeek]

print weekDay(2013, 6, 15) == (6, 'Saturday')
print weekDay(1969, 7, 20) == (0, 'Sunday')
print weekDay(1945, 4, 30) == (1, 'Monday')
print weekDay(1900, 1, 1)  == (1, 'Monday')
print weekDay(1789, 7, 14) == (2, 'Tuesday')

1
为什么我们需要进行aux+100/400而不是aux/400?你能解释一下吗? - himanshu219
3
Python3:只需在上面的函数中将所有“/”更改为“//”,它就可以完美运行。 - chabir
1
因为每400年有一个例外,不需要遵守闰年规则,而aux是从year -1700推导出来的,所以我们需要加上100使其成为400的倍数。例如:2000 - 1700 = 300,所以+ 100给我们400。不确定为什么在那个时候要使用aux来确定闰年,而不是直接使用year本身。 - not2savvy
这里的 offset 是什么? - Shyam3089

18

如果你有日期字符串,使用Pandas的时间戳可能更容易

import pandas as pd
df = pd.Timestamp("2019-04-12")
print(df.dayofweek, df.weekday_name)

输出:

4 Friday

15

这是一个简单的代码片段来解决这个问题

import datetime

intDay = datetime.date(year=2000, month=12, day=1).weekday()
days = ["Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday", "Sunday"]
print(days[intDay])

输出应该是:

Friday

12

如果日期是一个日期时间对象,这是一个解决方案。

import datetime
def dow(date):
    days=["Monday","Tuesday","Wednesday","Thursday","Friday","Saturday","Sunday"]
    dayNumber=date.weekday()
    print days[dayNumber]

10

假设你有一个 timeStamp: 字符串变量,格式为YYYY-MM-DD HH:MM:SS

步骤1: 使用以下代码将其转换为dateTime函数...

df['timeStamp'] = pd.to_datetime(df['timeStamp'])

步骤2:现在您可以按照以下方式提取所有所需的特征,这将为每个字段创建新列- 小时、月份、星期几、年份、日期。

df['Hour'] = df['timeStamp'].apply(lambda time: time.hour)
df['Month'] = df['timeStamp'].apply(lambda time: time.month)
df['Day of Week'] = df['timeStamp'].apply(lambda time: time.dayofweek)
df['Year'] = df['timeStamp'].apply(lambda t: t.year)
df['Date'] = df['timeStamp'].apply(lambda t: t.day)

这会编辑我的 Elasticsearch 数据/列吗?对我来说,这将使我能够在工作日使用桶聚合等功能。 - Cornelis

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接