使用Python ......
如何获取特定周内的日期列表?
像...一样的东西。
{
'1' : ['01/03/2010','01/04/2010','01/05/2010','01/06/2010','01/07/2010','01/08/2010','01/09/2010'],
'2' : ['01/10/2010','01/11/2010','01/12/2010','01/13/2010','01/14/2010','01/15/2010','01/16/2010']
}
本例中字典的关键字是周数。
答案 0 :(得分:17)
小心!如果你想定义你自己的周数,你可以使用in your first question提供的生成器表达式,顺便说一下,得到了一个很棒的答案)。如果您想遵循周年纪念的ISO惯例,您需要小心:
一年的第一个日历周是 包含第一个的那个 那年的星期四和[...] 一个日历年的最后一个日历周 就在前一周 下一个第一个日历周 历年。
因此,例如, 2010年1月1日和2日不是2010年第一周,而是2009年第53周。
Python提供了一个使用ISO日历查找周数的模块:
示例代码:
h[1] >>> import datetime
h[1] >>> Jan1st = datetime.date(2010,1,1)
h[1] >>> Year,WeekNum,DOW = Jan1st.isocalendar() # DOW = day of week
h[1] >>> print Year,WeekNum,DOW
2009 53 5
再次注意,2010年1月1日对应于2009年第53周。
使用上一个答案中提供的生成器:
from datetime import date, timedelta
def allsundays(year):
"""This code was provided in the previous answer! It's not mine!"""
d = date(year, 1, 1) # January 1st
d += timedelta(days = 6 - d.weekday()) # First Sunday
while d.year == year:
yield d
d += timedelta(days = 7)
Dict = {}
for wn,d in enumerate(allsundays(2010)):
# This is my only contribution!
Dict[wn+1] = [(d + timedelta(days=k)).isoformat() for k in range(0,7) ]
print Dict
Dict包含您请求的字典。
答案 1 :(得分:5)
你如何识别周?在这里,我确定了一周中的一天,使用一个函数来获取该周的星期日(在您的示例中使用的函数),然后返回它以及接下来的6天。
import datetime
one_day = datetime.timedelta(days=1)
def get_week(date):
"""Return the full week (Sunday first) of the week containing the given date.
'date' may be a datetime or date instance (the same type is returned).
"""
day_idx = (date.weekday() + 1) % 7 # turn sunday into 0, monday into 1, etc.
sunday = date - datetime.timedelta(days=day_idx)
date = sunday
for n in xrange(7):
yield date
date += one_day
print list(get_week(datetime.datetime.now().date()))
# [datetime.date(2010, 1, 3), datetime.date(2010, 1, 4),
# datetime.date(2010, 1, 5), datetime.date(2010, 1, 6),
# datetime.date(2010, 1, 7), datetime.date(2010, 1, 8),
# datetime.date(2010, 1, 9)]
print [d.isoformat() for d in get_week(datetime.datetime.now().date())]
# ['2010-01-03', '2010-01-04', '2010-01-05', '2010-01-06', '2010-01-07',
# '2010-01-08', '2010-01-09']
答案 2 :(得分:1)
您可以使用日期时间模块。您可以指定格式和所有内容。这是链接:http://docs.python.org/library/datetime.html
查看datetime.datetime(params)和datetime.timedelta(params)。希望一切顺利; - )
示例:
import datetime
numweeks = 5
start_date = datetime.datetime(year=2010,month=1,day=4)
weeks = {}
offset = datetime.timedelta(days=0)
for week in range(numweeks):
this_week = []
for day in range(7):
date = start_date + offset
date = date.strftime( some_format_string )
this_week.append( date )
offset += datetime.timedelta(days=1)
weeks[week] = this_week
答案 3 :(得分:1)
如果您对ISO标准没问题:
>>> import collections
>>> dd = collections.defaultdict(list)
>>> jan1 = datetime.date(2010, 1, 1)
>>> oneday = datetime.timedelta(days=1)
>>> allyear = [jan1 + k*oneday for k in range(365 + 6)]
>>> for d in allyear:
... y, w, wd = d.isocalendar()
... if y == 2010: dd[w].append(d.strftime('%m/%d/%Y'))
...
这会产生与您正在寻找的结果略有不同的结果(根据ISO标准,周数从星期一开始,而不是星期日......),例如:
>>> dd[1]
['01/04/2010', '01/05/2010', '01/06/2010', '01/07/01/2010', '01/08/2010', '01/09/2010', '01/10/2010']
但你可以通过模拟一个适当的“off by one”错误来调整它! - )
calendar模块允许您将任何工作日设置为“一周的第一天”,但没有简单的方法来获取所有周(当一周分为两个月时没有重复),所以我认为工作直接关闭datetime可能是一个更好的主意。
答案 4 :(得分:1)
我在阅读完这个问题后开发了一个3行方法:
from datetime import timedelta
def get_week_dates(base_date, start_day, end_day=None):
"""
Return entire week of dates based on given date limited by start_day and end_day.
If end_day is None, return only start_day.
>>> from datetime import date
>>> get_week_dates(date(2015,1,16), 3, 5)
[datetime.date(2015, 1, 14), datetime.date(2015, 1, 15), datetime.date(2015, 1, 16)]
>>> get_week_dates(date(2015,1,15), 2, 5)
[datetime.date(2015, 1, 13), datetime.date(2015, 1, 14), datetime.date(2015, 1, 15), datetime.date(2015, 1, 16)]
"""
monday = base_date - timedelta(days=base_date.isoweekday() - 1)
week_dates = [monday + timedelta(days=i) for i in range(7)]
return week_dates[start_day - 1:end_day or start_day]
使用get_week_dates(date.today(), 1, 7)
获取当前的工作日期。
答案 5 :(得分:0)
以下是一些代码:
import datetime
now = datetime.datetime.now()
now_day_1 = now - datetime.timedelta(days=now.weekday())
dates = {}
for n_week in range(3):
dates[n_week] = [(now_day_1 + datetime.timedelta(days=d+n_week*7)).strftime("%m/%d/%Y") for d in range(7)]
print dates
打印:
{
0: ['01/04/2010', '01/05/2010', '01/06/2010', '01/07/2010', '01/08/2010', '01/09/2010', '01/10/2010'],
1: ['01/11/2010', '01/12/2010', '01/13/2010', '01/14/2010', '01/15/2010', '01/16/2010', '01/17/2010'],
2: ['01/18/2010', '01/19/2010', '01/20/2010', '01/21/2010', '01/22/2010', '01/23/2010', '01/24/2010']
}
答案 6 :(得分:-1)
current_week = datetime.datetime.now().isocalendar()[1]