需要星期日作为一周的第一天

时间:2013-06-10 02:12:09

标签: python datetime pandas python-datetime

我希望星期日为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来获取日期时间。)

2 个答案:

答案 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