如何在Python中的几天,几小时,几周和几个月后迭代一次?

sve*_*joh 60 python datetime

如何在数天,数小时,数周或数月后迭代一次?

就像是:

for date in foo(from_date, to_date, delta=HOURS):
    print date
Run Code Online (Sandbox Code Playgroud)

其中foo是一个函数,返回一个迭代器.我一直在查看日历模块,但这只适用于特定年份或月份,而不是日期之间.

Tho*_*ele 97

使用dateutil及其rrule实现,如下所示:

from dateutil import rrule
from datetime import datetime, timedelta

now = datetime.now()
hundredDaysLater = now + timedelta(days=100)

for dt in rrule.rrule(rrule.MONTHLY, dtstart=now, until=hundredDaysLater):
    print dt
Run Code Online (Sandbox Code Playgroud)

输出是

2008-09-30 23:29:54
2008-10-30 23:29:54
2008-11-30 23:29:54
2008-12-30 23:29:54
Run Code Online (Sandbox Code Playgroud)

每月,每月,每周,每日,每小时,每分钟或每日更换一次.替换dtstart,直到你想要的任何日期时间对象.

该配方具有适用于所有情况的优势,包括每月.我能找到的唯一警告是,如果你传递的是所有月份都不存在的天数,它会跳过这几个月.

  • http://niemeyer.net/python-dateutil解释了如何使用它来检索"月份指定日期的日期,除非它超过月末,在这种情况下它将是该月的最后一天" .这修复了您列出的一个警告.例如,now = datetime(2010,8,31,1,1,1); 对于rrule.rrule中的dt(rrule.MONTHLY,dtstart = now,bymonthday =(31,-1),count = 6):print dt (2认同)

Dzi*_*inX 43

我不认为Python库中有一个方法,但您可以使用datetime模块轻松创建一个方法:

from datetime import date, datetime, timedelta

def datespan(startDate, endDate, delta=timedelta(days=1)):
    currentDate = startDate
    while currentDate < endDate:
        yield currentDate
        currentDate += delta
Run Code Online (Sandbox Code Playgroud)

然后你可以像这样使用它:

>>> for day in datespan(date(2007, 3, 30), date(2007, 4, 3), 
>>>                     delta=timedelta(days=1)):
>>>     print day
2007-03-30
2007-03-31
2007-04-01
2007-04-02
Run Code Online (Sandbox Code Playgroud)

或者,如果您希望减小delta:

>>> for timestamp in datespan(datetime(2007, 3, 30, 15, 30), 
>>>                           datetime(2007, 3, 30, 18, 35), 
>>>                           delta=timedelta(hours=1)):
>>>     print timestamp
2007-03-30 15:30:00
2007-03-30 16:30:00
2007-03-30 17:30:00
2007-03-30 18:30:00
Run Code Online (Sandbox Code Playgroud)

  • 您不能指定一个月的时间增量 (3认同)

小智 7

我使用熊猫和日期时间库实现了这一点,如下所示。对我来说方便多了。

import pandas as pd
from datetime import datetime


DATE_TIME_FORMAT = '%Y-%m-%d %H:%M:%S'

start_datetime = datetime.strptime('2018-05-18 00:00:00', DATE_TIME_FORMAT)
end_datetime = datetime.strptime('2018-05-23 13:00:00', DATE_TIME_FORMAT)

timedelta_index = pd.date_range(start=start_datetime, end=end_datetime, freq='H').to_series()
for index, value in timedelta_index.iteritems():
    dt = index.to_pydatetime()
    print(dt)
Run Code Online (Sandbox Code Playgroud)

  • 欢迎使用堆栈溢出!一般来说,如果答案包括对代码意图做什么的解释,以及为什么在不引入其他人的情况下解决问题,答案会更有帮助。 (2认同)

gil*_*tay 6

对于几个月的迭代,你需要一个不同的食谱,因为timedeltas不能表达"一个月".

from datetime import date

def jump_by_month(start_date, end_date, month_step=1):
    current_date = start_date
    while current_date < end_date:
        yield current_date
        carry, new_month = divmod(current_date.month - 1 + month_step, 12)
        new_month += 1
        current_date = current_date.replace(year=current_date.year + carry,
                                            month=new_month)
Run Code Online (Sandbox Code Playgroud)

(注意:您必须从模拟操作的月份中减去1,然后将其添加回new_month,因为datetime.date从1开始的几个月开始)