import datetime as DT
import itertools
start_date=DT.date(2008,5,5)
def mkdate(datestring):
return DT.datetime.strptime(datestring, "%Y-%m-%d").date()
def fortnight(date):
return (date-start_date).days //14
raw = ("2010-08-01",
"2010-06-25",
"2010-07-01",
"2010-07-08")
transactions=[(date,"Some data") for date in map(mkdate,raw)]
transactions.sort(key=lambda (date,data):date)
for key,grp in itertools.groupby(transactions,key=lambda (date,data):fortnight(date)):
print(key,list(grp))
выходы
# (55, [(datetime.date(2010, 6, 25), 'Some data')])
# (56, [(datetime.date(2010, 7, 1), 'Some data'), (datetime.date(2010, 7, 8), 'Some data')])
# (58, [(datetime.date(2010, 8, 1), 'Some data')])
Обратите внимание, что 2010-6-25 находится на 55-й неделе, начиная с 2008-5-5, а 2010-7-1 на 56-м. Если вы хотите, чтобы они сгруппировались, просто измените start_date
(на что-то вроде 2008-5-16).
PS. Ключевым инструментом, использованным выше, является itertools.groupby
, что подробно объясняется здесь .
Редактировать: lambda
просто способ сделать "анонимными" функциями . (Они являются анонимными в том смысле, что им не дают имена, подобные функциям, определенным def
). Везде, где вы видите лямбду, также можно использовать def
для создания эквивалентной функции. Например, вы можете сделать это:
import operator
transactions.sort(key=operator.itemgetter(0))
def transaction_fortnight(transaction):
date,data=transaction
return fortnight(date)
for key,grp in itertools.groupby(transactions,key=transaction_fortnight):
print(key,list(grp))