我希望星期日为0,但是当使用datetime weeday方法时它是6:
datetime(2013, 6, 9, 11, 59, 59, 1).weekday() # this returns 6
我的语言环境是:“en_US.UTF-8”所以星期日应为0(当我在bash提示符下运行'locale day'时,它正确显示'Sunday'作为一周的第一天)。
$ locale day
Sunday;Monday;Tuesday;Wednesday;Thursday;Friday;Saturday
如何让python将星期日显示为一周的第一天?
(我正在使用pandas时间序列并调用.date
来获取日期时间。)
答案 0 :(得分:8)
试试这个:
(datetime.datetime(2013, 6, 9, 11, 59, 59, 1).weekday() + 1) % 7
答案 1 :(得分:2)
使用dayofweek属性(更快),而不是通过日期(创建日期时间对象):
In [1]: rng = pd.date_range('1/1/2013', periods=72, freq='D')
In [2]: (rng.dayofweek + 1 ) % 7
Out[2]:
array([2, 3, 4, 5, 6, 0, 1, 2, 3, 4, 5, 6, 0, 1, 2, 3, 4, 5, 6, 0, 1, 2, 3,
4, 5, 6, 0, 1, 2, 3, 4, 5, 6, 0, 1, 2, 3, 4, 5, 6, 0, 1, 2, 3, 4, 5,
6, 0, 1, 2, 3, 4, 5, 6, 0, 1, 2, 3, 4, 5, 6, 0, 1, 2, 3, 4, 5, 6, 0,
1, 2, 3], dtype=int32)
您可以将此属性设为:
In [3]: rng.my_dayofweek = (rng.dayofweek + 1 ) % 7
同样,您可以计算自己的一周:
In [4]: rng.my_week = rng.map(lambda x: x.week if x.dayofweek else x.week - 1)
然后,您可以将其作为属性使用。
datetime.date weekday
方法不是特定于语言环境的,它是硬编码的(这是它的文档字符串):
返回日期所代表的星期几
Monday == 0 ... Sunday == 6