Pergunta

A partir do console IPython:

In [16]: b
Out[16]: datetime.datetime(2008, 3, 1, 0, 0)

In [17]: e
Out[17]: datetime.datetime(2010, 5, 2, 0, 0)

In [18]: rrule(MONTHLY).between(b, e, inc=True)
Out[18]:
[datetime.datetime(2009, 3, 6, 14, 42, 1),
 datetime.datetime(2009, 4, 6, 14, 42, 1),
 datetime.datetime(2009, 5, 6, 14, 42, 1),
 datetime.datetime(2009, 6, 6, 14, 42, 1),
 datetime.datetime(2009, 7, 6, 14, 42, 1),
 datetime.datetime(2009, 8, 6, 14, 42, 1),
 datetime.datetime(2009, 9, 6, 14, 42, 1),
 datetime.datetime(2009, 10, 6, 14, 42, 1),
 datetime.datetime(2009, 11, 6, 14, 42, 1),
 datetime.datetime(2009, 12, 6, 14, 42, 1),
 datetime.datetime(2010, 1, 6, 14, 42, 1),
 datetime.datetime(2010, 2, 6, 14, 42, 1),
 datetime.datetime(2010, 3, 6, 14, 42, 1),
 datetime.datetime(2010, 4, 6, 14, 42, 1)]

Como posso fazer datas between() de retorno a partir da (b) data de início?

Foi útil?

Solução

Você precisa passar b em RRULE, como este:

rrule(MONTHLY, dtstart = b).between(b, e, inc=True)

A partir desses documentos ( http://labix.org/python-dateutil ), parece chamando RRULE sem especificar dtstart usará datetime.datetime.now () como o ponto de partida para a sequência que você está aplicando mais tarde between para. É por isso que os seus valores começam em 2009-03-06.

Licenciado em: CC-BY-SA com atribuição
Não afiliado a StackOverflow
scroll top