croniter为datetime对象提供类似cron格式的迭代
croniter-hpx的Python项目详细描述
Introduction
内容
croniter以cron格式为datetime对象提供迭代。
_ _ ___ _ __ ___ _ __ (_) |_ ___ _ __ / __| '__/ _ \| '_ \| | __/ _ \ '__| | (__| | | (_) | | | | | || __/ | \___|_| \___/|_| |_|_|\__\___|_|
Usage
简单的用法示例如下:
>>> from croniter import croniter >>> from datetime import datetime >>> base = datetime(2010, 1, 25, 4, 46) >>> iter = croniter('*/5 * * * *', base) # every 5 minites >>> print iter.get_next(datetime) # 2010-01-25 04:50:00 >>> print iter.get_next(datetime) # 2010-01-25 04:55:00 >>> print iter.get_next(datetime) # 2010-01-25 05:00:00 >>> >>> iter = croniter('2 4 * * mon,fri', base) # 04:02 on every Monday and Friday >>> print iter.get_next(datetime) # 2010-01-26 04:02:00 >>> print iter.get_next(datetime) # 2010-01-30 04:02:00 >>> print iter.get_next(datetime) # 2010-02-02 04:02:00
您只需要知道构造函数和get_next,这些签名如下:
>>> def __init__(self, cron_format, start_time=time.time())
croniter从“start_time”开始与“cron_format”一起迭代。 cron_格式为“每周的每月一天的最小小时”,请参阅 http://en.wikipedia.org/wiki/Cron了解详细信息。:
>>> def get_next(self, ret_type=float)
get_next return下次使用“ret_type”进行迭代。 ret_type只接受'float'或'datetime'。
现在,支持get-prev方法。(>;=0.2.0):
>>> base = datetime(2010, 8, 25) >>> itr = croniter('0 0 1 * *', base) >>> print itr.get_prev(datetime) # 2010-08-01 00:00:00 >>> print itr.get_prev(datetime) # 2010-07-01 00:00:00 >>> print itr.get_prev(datetime) # 2010-06-01 00:00:00
Develop this package
git clone https://github.com/kiorky/croniter.git cd croniter python bootstrap.py -d bin/buildout -vvvvvvN bin/test
Contributors
感谢所有为这个项目做出贡献的人! 如果您有贡献,但没有列在下面,请让我知道。
- mrmachine
- Hinnack
- shazow
- kiorky
- jlsandell
- mag009
- djmitche
- GreatCombinator
- chris-baynes
- ipartola
- yuzawa-san
Changelog
0.3.12 (unreleased)
- 什么都没变。
0.3.11 (2016-01-13)
- 错误修复:使用月的最后一天令牌时,get-prev api崩溃。一些 缺少基本逻辑。 [iddo aviram<;iddo.aviram@similarweb.com>;]
0.3.10 (2015-11-29)
- 因为月变量 未正确更新 [iddo aviram<;iddo.aviram@similarweb.com>;]
0.3.9 (2015-11-19)
- 不使用日期时间函数Python2.6不支持 [皮特桑德]
0.3.8 (2015-06-23)
- 通过设置为0截断微秒 [科里·赖特]
0.3.7 (2015-06-01)
- 将射程中的太阳thu转换为int 0,即 识别为空字符串;解决方案是将sun转换为字符串“0”
0.3.6 (2015-05-29)
- 修复未给定启动时间时的默认行为 start_time参数的默认值是在模块初始化时间而不是调用时间计算的。
- 修复时区支持并根据系统时区停止
0.3.5 (2014-08-01)
- 支持“L”(每月最后一天)
0.3.4 (2014-01-30)
- python 3兼容性
- 质量保证关系