A Python library that converts cron expressions into human readable strings.
Project description
Cron Descriptor
A Python library that converts cron expressions into human readable strings. Ported to Python from https://github.com/bradyholt/cron-expression-descriptor.
Author: Adam Schubert (https://www.salamek.cz)
Original Author & Credit: Brady Holt (http://www.geekytidbits.com)
License: MIT
Features
- Supports all cron expression special characters including * / , - ? L W, #
- Supports 5, 6 (w/ seconds or year), or 7 (w/ seconds and year) part cron expressions
- Provides casing options (Sentence, Title, Lower, etc.)
- Localization with support for 17 languages
- Supports Python 3.8 - 3.12
Installation
Using PIP
pip install cron-descriptor
Usage example
Simple
from cron_descriptor import get_description, ExpressionDescriptor
print(get_description("* 2 3 * *"))
#OR
print(str(ExpressionDescriptor("* 2 3 * *")))
Advanced
# Consult Options.py/CasingTypeEnum.py/DescriptionTypeEnum.py for more info
from cron_descriptor import Options, CasingTypeEnum, DescriptionTypeEnum, ExpressionDescriptor
descriptor = ExpressionDescriptor(
expression = "*/10 * * * *",
casing_type = CasingTypeEnum.Sentence,
use_24hour_time_format = True
)
# GetDescription uses DescriptionTypeEnum.FULL by default:
print(descriptor.get_description())
print("{}".format(descriptor))
# Or passing Options class as second argument:
options = Options()
options.casing_type = CasingTypeEnum.Sentence
options.use_24hour_time_format = True
descriptor = ExpressionDescriptor("*/10 * * * *", options)
print(descriptor.get_description(DescriptionTypeEnum.FULL))
Languages Available
Language | Locale Code | Contributor |
---|---|---|
English | en | Brady Holt |
Brazilian | pt_PT | Renato Lima |
Chinese Simplified | zh_CN | Star Peng |
Spanish | es_ES | Ivan Santos |
Norwegian | nb_NO | Siarhei Khalipski |
Turkish | tr_TR | Mustafa SADEDİL |
Dutch | nl_NL | TotalMace |
Russian | ru_RU | LbISS |
French | fr_FR | Arnaud TAMAILLON |
German | de_DE | Michael Schuler |
Ukrainian | uk_UA | Taras |
Italian | it_IT | rinaldihno |
Czech | cs_CZ | Adam Schubert |
Swedish | sv_SE | Åke Engelbrektson |
Tamil | ta_IN | Sankar Hari |
Persian | fa_IR | M. Yas. Davoodeh |
Korean | ko_KR | KyuJoo Han |
Japanese | ja_JP | Tho Nguyen |
Original Source
Ports
- Java - https://github.com/RedHogs/cron-parser
- Ruby - https://github.com/alpinweis/cronex
- Golang - https://github.com/jsuar/go-cron-descriptor
Running Unit Tests
python setup.py test
Translating
cron-descriptor is using Gettext for translations.
To create new translation or edit existing one, i suggest using Poedit.
You can copy/rename and translate any file from locale
directory:
cp ./cron_descriptor/locale/de_DE.po ./cron_descriptor/locale/YOUR_LOCALE_CODE.po
poedit ./cron_descriptor/locale/YOUR_LOCALE_CODE.po
or you can generate new untranslated *.po file from sources by running in cron_descriptor
directory:
cd cron_descriptor
xgettext *.py -o locale/YOUR_LOCALE_CODE.po
Generating *.mo file from *.po file. In root directory run command:
msgfmt -o cron_descriptor/locale/YOUR_LOCALE_CODE.mo cron_descriptor/locale/YOUR_LOCALE_CODE.po
Developing
All suggestions and PR's are welcomed
Just clone this repository and register pre-commit hook by running:
ln -s ../../pre-commit.sh .git/hooks/pre-commit
Then install dev requirements:
pip install ruff
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file cron_descriptor-1.4.5.tar.gz
.
File metadata
- Download URL: cron_descriptor-1.4.5.tar.gz
- Upload date:
- Size: 30.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.11.2
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | f51ce4ffc1d1f2816939add8524f206c376a42c87a5fca3091ce26725b3b1bca |
|
MD5 | da577b24db86165963f92433d307967e |
|
BLAKE2b-256 | 028370bd410dc6965e33a5460b7da84cf0c5a7330a68d6d5d4c3dfdb72ca117e |
File details
Details for the file cron_descriptor-1.4.5-py3-none-any.whl
.
File metadata
- Download URL: cron_descriptor-1.4.5-py3-none-any.whl
- Upload date:
- Size: 50.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.11.2
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 736b3ae9d1a99bc3dbfc5b55b5e6e7c12031e7ba5de716625772f8b02dcd6013 |
|
MD5 | 3c4f257c05969cdb53a09af2c77ed66a |
|
BLAKE2b-256 | 88202cfe598ead23a715a00beb716477cfddd3e5948cf203c372d02221e5b0c6 |