crontools

python cron tools

UNLICENSE License

Downloads
262
Stars
7
Committers
2

=========
crontools

.. image:: https://static.pepy.tech/personalized-badge/crontools?period=month&units=international_system&left_color=grey&right_color=orange&left_text=Downloads/month :target: https://pepy.tech/project/crontools :alt: Downloads/month .. image:: https://github.com/dapper91/crontools/actions/workflows/test.yml/badge.svg?branch=master :target: https://github.com/dapper91/crontools/actions/workflows/test.yml :alt: Build status .. image:: https://img.shields.io/pypi/l/crontools.svg :target: https://pypi.org/project/crontools :alt: License .. image:: https://img.shields.io/pypi/pyversions/crontools.svg :target: https://pypi.org/project/crontools :alt: Supported Python versions .. image:: https://codecov.io/gh/dapper91/crontools/branch/master/graph/badge.svg :target: https://codecov.io/gh/dapper91/crontools :alt: Code coverage

crontools is a library that allows you to parse crontab expression and iterate over scheduled fire times.

Features:

  • crontab expression parser
  • optional seconds field support
  • optional year field support
  • crontab fire time sequential iteration support

Installation

You can install crontools with pip:

.. code-block:: console

$ pip install crontools

Quickstart

Get next cron fire time:


.. code-block:: python

    >>> import datetime as dt
    >>> import crontools as ct
    >>>
    >>> tz = dt.timezone.utc
    >>> now = dt.datetime.fromisoformat('2020-02-29 23:59:59.999+00:00')
    >>> ct = ct.Crontab.parse(
    ...     '* * * * * * *',
    ...     seconds_ext=True,
    ...     years_ext=True,
    ...     tz=tz,
    ... )
    >>>
    >>> print(f"Next fire time: {ct.next_fire_time(now=now)}")
    Next fire time: 2020-03-01 00:00:00+00:00


Iteration over cron fire times starting from now:

.. code-block:: python

>>> import crontools as ct
>>>
>>> tz = dt.timezone.utc
>>> now = dt.datetime.fromisoformat('2021-02-01 00:00:00+00:00')
>>> ct = ct.Crontab.parse(
...     '30 30 12-16/2 1,2 JAN SAT,SUN *',
...     seconds_ext=True,
...     years_ext=True,
...     tz=tz,
... )
>>>
>>> cron_iter = ct.iter(start_from=now)
>>> for n, fire_datetime in zip(range(1, 31), cron_iter):
...     print("{n:2}: {dt}".format(n=n, dt=fire_datetime))
...
...
 1: 2022-01-01 12:30:30+00:00
 2: 2022-01-01 14:30:30+00:00
 3: 2022-01-01 16:30:30+00:00
 4: 2022-01-02 12:30:30+00:00
 5: 2022-01-02 14:30:30+00:00
 6: 2022-01-02 16:30:30+00:00
 7: 2022-01-08 12:30:30+00:00
 8: 2022-01-08 14:30:30+00:00
 9: 2022-01-08 16:30:30+00:00
10: 2022-01-09 12:30:30+00:00
11: 2022-01-09 14:30:30+00:00
12: 2022-01-09 16:30:30+00:00
13: 2022-01-15 12:30:30+00:00
14: 2022-01-15 14:30:30+00:00
15: 2022-01-15 16:30:30+00:00
16: 2022-01-16 12:30:30+00:00
17: 2022-01-16 14:30:30+00:00
18: 2022-01-16 16:30:30+00:00
19: 2022-01-22 12:30:30+00:00
20: 2022-01-22 14:30:30+00:00
21: 2022-01-22 16:30:30+00:00
22: 2022-01-23 12:30:30+00:00
23: 2022-01-23 14:30:30+00:00
24: 2022-01-23 16:30:30+00:00
25: 2023-01-01 12:30:30+00:00
26: 2023-01-01 14:30:30+00:00
27: 2023-01-01 16:30:30+00:00
28: 2023-01-02 12:30:30+00:00
29: 2023-01-02 14:30:30+00:00
30: 2023-01-02 16:30:30+00:00