Skip to main content

Date-expression domain specific language parsing. A neat way to express things like "First Saturday of any year", or "3rd thursdays each month" and such

Project description

Cronspell Python Package / CLI Tool

Chronometry Spelled Out

Github Pages

Details Tests License - MIT
Features linting - Ruff types - mypy test - pytest Pre-Commit docs - mkdocs

Date-expression domain specific language (DSL) parsing. A neat way to express things like "First Saturday of any year", or "3rd thursdays each month" and such.

DSL Example

To get the last saturday of last month:

"now /m -1d /sat"

The same, more verbose:

"now /month -1day /sat"

Installation

Python module

If you need just the python function to parse cronspell expressions:

pip install cronspell
from cronspell import parse

date_of_interest = parse("now /m -1d /sat")

Command Line Interface

If you like to use it in your command line:

pip install 'cronspell[cli]'
cronspell parse "now /m -1d /sat"

Features

Python

Cronspell is heavily inspired by Grafana's relative Date picker user interface. It shines when configuration is needed to reflect irregular date-distances such as in the example below.

cronspell lets you express relative dates such as "last saturday of last month" and converts it to a date object for use in your python project.

from cronspell import parse

# Cronspell's purpose is mostly to parse configuration files written in yaml
# and therein express relative date times in a human friendly manner.

# here is but a simple demo:
last_saturday = parse("now/sat")
...

Cli

The same interface, exposed to the command line. Formatted via isodate by default -- which is open for configuration using the --format option.

This is how you get the last saturday of the current month, for example:

cronspell parse "now /month + 34 days /m -1d /sat"

Pre-Commit Hook: Validation

Cronspell comes with a pre-commit hook that validates configured date-expressions based on yamlpath.

Check out the documentation for detailed instructions.

Credits

  • Domain-Specific-Language Parser: TextX
  • This package was created with The Hatchlor project template.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

cronspell-0.2.1.tar.gz (12.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

cronspell-0.2.1-py3-none-any.whl (13.8 kB view details)

Uploaded Python 3

File details

Details for the file cronspell-0.2.1.tar.gz.

File metadata

  • Download URL: cronspell-0.2.1.tar.gz
  • Upload date:
  • Size: 12.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.0.1 CPython/3.12.8

File hashes

Hashes for cronspell-0.2.1.tar.gz
Algorithm Hash digest
SHA256 69c2804484462652478c2463e7a007b708198dd79386db748c307746f8be4627
MD5 cfe350084be4a6a7a2744fb9fa0f150b
BLAKE2b-256 1e3ca189b2573d4b9b9850a7224592d88acf1d328bc4757b385c17e17b3b1aef

See more details on using hashes here.

Provenance

The following attestation bundles were made for cronspell-0.2.1.tar.gz:

Publisher: build.yml on iilei/cronspell

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file cronspell-0.2.1-py3-none-any.whl.

File metadata

  • Download URL: cronspell-0.2.1-py3-none-any.whl
  • Upload date:
  • Size: 13.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.0.1 CPython/3.12.8

File hashes

Hashes for cronspell-0.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 98ebc22833e91a8768e226ea38286dbc57d259add5d029c7e4265e489497ce22
MD5 87f4205980d362f61adacf7894f26c4e
BLAKE2b-256 e46968daf15c6ae26d8767393a61afa2d91dcd920038dea7d4a64de406f069d5

See more details on using hashes here.

Provenance

The following attestation bundles were made for cronspell-0.2.1-py3-none-any.whl:

Publisher: build.yml on iilei/cronspell

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page