如何创建具有周数范围的系列?



我希望从现在开始创建过去 6 个工作周的列表。

我目前有效的是:

import datetime
cww = datetime.datetime.now().isocalendar()[1]
cy = datetime.datetime.now().isocalendar()[0]
l6ww = [str(cy)[2:]+'WW'+str(w) for w in range(cww-5,cww+1)]
print l6ww
['18WW35', '18WW36', '18WW37', '18WW38', '18WW39', '18WW40']

这将一直持续到明年的第一个WW。 我可以想到几种蛮力方法来解决这个问题,但想要一些更优雅的东西。

您可以使用datetime.timedelta()

import datetime
now = datetime.datetime.now().isocalendar()
l6ww = [(datetime.datetime.now() - datetime.timedelta(weeks=x)).isocalendar() for x in range(6)]
final = [str(i[0])[2:] + 'WW' + str(i[1]) for i in l6ww][::-1]

收益 率:

['18WW35', '18WW36', '18WW37', '18WW38', '18WW39', '18WW40']

即使您进入新的一年,无论是向前 x 周还是在过去 x 周内,这也将起作用。您也可以稍微修改此代码以向前推进:

l6ww = [(datetime.datetime.now() + datetime.timedelta(weeks=x)).isocalendar() for x in range(15)]
final = [str(i[0])[2:] + 'WW' + str(i[1]) for i in l6ww]

收益 率:

['18WW40', '18WW41', '18WW42', '18WW43', '18WW44', '18WW45', '18WW46', '18WW47', '18WW48', '18WW49', '18WW50', '18WW51', '18WW52', '19WW1', '19WW2']

最新更新