Development Status
- 5 - Production/Stable
Environment
- Web Environment
- Console
Intended Audience
- Developers
Operating System
- OS Independent
Programming Language
- Python
- Python :: Implementation :: CPython
- Python :: Implementation :: PyPy
- Python :: 3.9
- Python :: 3.10
- Python :: 3.11
- Python :: 3.12
- Python :: 3.13
Topic
- Software Development
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 ~31 languages
- Supports Python 3.9 - 3.13
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(f"{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 |
| Chinese Simplified | zh_CN | Star Peng |
| Chinese Traditional | zh_TW | Ricky Chiang |
| Czech | cs_CZ | Adam Schubert |
| Danish | da_DK | Rasmus Melchior Jacobsen |
| Dutch | nl_NL | TotalMace |
| Finnish | fi_FI | Mikael Rosenberg |
| French | fr_FR | Arnaud TAMAILLON |
| German | de_DE | Michael Schuler |
| Hebrew | he_IL | Ariel Deil |
| Hungarian | hu_HU | Varga Miklós |
| Italian | it_IT | rinaldihno |
| Japanese | ja_JP | Tho Nguyen |
| Korean | ko_KR | KyuJoo Han |
| Norwegian | nb_NO | Siarhei Khalipski |
| Persian | fa_IR | A. Bahrami |
| Polish | pl_PL | foka |
| Portuguese | pt_PT | Renato Lima |
| Portuguese (Brazil) | pt_BR | Renato Lima |
| Romanian | ro_RO | Illegitimis |
| Russian | ru_RU | LbISS |
| Slovenian | sl_SI | Jani Bevk |
| Spanish | es_ES | Ivan Santos |
| Spanish (Mexico) | es_MX | Ion Mincu |
| Swedish | sv_SE | Åke Engelbrektson |
| Vietnamese | vi_VN | Nguyen Duc Son |
| Turkish | tr_TR | Mustafa SADEDİL |
| Tamil | ta_IN | Sankar Hari |
| Ukrainian | uk_UA | Taras |
| Greek | el_GR | hardra1n |
| Kazakh | kk_KZ | hardra1n |
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 ../../code-check.sh .git/hooks/pre-commit
Then install dev requirements:
pip install .[dev,test]