AWS Croniter is a Python package for parsing, validating, and calculating occurrences of AWS EventBridge cron expressions. AWS cron expressions are a powerful way to schedule events, but they differ from standard Unix cron syntax. This library makes it easy to work with AWS-specific cron schedules programmatically.
AWS Croniter was inspired by two existing packages,
aws-cron-expression-validator
and
pyawscron
, which serve similar purposes. The
aws-cron-expression-validator
package focuses solely on validating AWS cron expressions, while pyawscron
provides
functionality for parsing and calculating schedules such as next and previous occurrences. However, both packages had
limitations, and users often needed to install and integrate both packages to work effectively with AWS cron schedules.
AWS Croniter was developed to address these issues by combining the features of both packages into a single, robust
solution that also provides an improved and comprehensive tool for working with AWS cron expressions.
- Validate AWS cron expressions against AWS EventBridge syntax.
- Parse and interpret cron rules with detailed validation error messages.
- Compute:
- Next and previous occurrence times for a given schedule.
- All occurrences of a schedule between two given dates.
- Handle special AWS cron syntax (e.g.,
?
,L
,W
,#
) and aliases for months (JAN
,FEB
, ...) and days of the week (SUN
,MON
, ...).
Install the package via pip:
pip install aws-croniter
from aws_croniter import AwsCroniter
cron_expression = "0 12 15 * ? 2023" # AWS cron syntax
aws_cron = AwsCroniter(cron_expression)
When an invalid AWS cron expression is passed, AwsCroniter
raises specific exceptions indicating the nature of the
error:
from aws_croniter import AwsCroniter
from aws_croniter.exceptions import AwsCroniterExpressionError
try:
invalid_cron = "0 18 ? * MON-FRI" # Missing fields
AwsCroniter(invalid_cron)
except AwsCroniterExpressionError as e:
print(f"Invalid cron expression: {e}")
# Output: Invalid cron expression: Incorrect number of values in '0 18 ? * MON-FRI'. 6 required, 5 provided.
The get_next
method retrieves the next occurrence(s) of the cron schedule from a specified date. This method
always returns a list with n
items and sets the items to None
if no valid occurrences are found.
from aws_croniter import AwsCroniter
from datetime import datetime, timezone
# AWS cron expression
cron_expression = "0 12 15 * ? 2023"
aws_cron = AwsCroniter(cron_expression)
# Starting datetime
start_date = datetime(2023, 12, 14, tzinfo=timezone.utc)
next_occurrence = aws_cron.get_next(start_date)
print(next_occurrence)
# Output: [datetime.datetime(2023, 12, 15, 12, 0, tzinfo=datetime.timezone.utc)]
from aws_croniter import AwsCroniter
from datetime import datetime, timezone
# AWS cron expression
cron_expression = "0 12 15 * ? 2023"
aws_cron = AwsCroniter(cron_expression)
# Starting datetime
start_date = datetime(2023, 9, 14, tzinfo=timezone.utc)
# Fetch the next 3 occurrences
next_occurrences = aws_cron.get_next(start_date, n=3)
print(next_occurrences)
# Output: [datetime.datetime(2023, 9, 15, 12, 0, tzinfo=datetime.timezone.utc),
# datetime.datetime(2023, 10, 15, 12, 0, tzinfo=datetime.timezone.utc),
# datetime.datetime(2023, 11, 15, 12, 0, tzinfo=datetime.timezone.utc)]
Setting inclusive=True
includes the start date in the results if it matches the schedule. The default is False
.
from aws_croniter import AwsCroniter
from datetime import datetime, timezone
# AWS cron expression
cron_expression = "0 12 15 * ? 2023"
aws_cron = AwsCroniter(cron_expression)
# Starting datetime
start_date = datetime(2023, 12, 15, 12, 0,
tzinfo=timezone.utc)
# Include the starting date in the results
next_occurrence_inclusive = aws_cron.get_next(start_date, inclusive=True)
print(next_occurrence_inclusive)
# Output: [datetime.datetime(2023, 12, 15, 12, 0, tzinfo=datetime.timezone.utc)]
The get_prev
method retrieves the previous occurrence(s) of the cron schedule from a specified date. This method
always returns a list with n
items and sets the items to None
if no valid occurrences are found.
from aws_croniter import AwsCroniter
from datetime import datetime, timezone
# AWS cron expression
cron_expression = "0 12 15 * ? 2023"
aws_cron = AwsCroniter(cron_expression)
# Starting datetime
start_date = datetime(2023, 12, 14, tzinfo=timezone.utc)
prev_occurrence = aws_cron.get_prev(start_date)
print(prev_occurrence)
# Output: [datetime.datetime(2023, 11, 15, 12, 0, tzinfo=datetime.timezone.utc)]
from aws_croniter import AwsCroniter
from datetime import datetime, timezone
# AWS cron expression
cron_expression = "0 12 15 * ? 2023"
aws_cron = AwsCroniter(cron_expression)
# Starting datetime
start_date = datetime(2023, 12, 14, tzinfo=timezone.utc)
# Fetch the previous 2 occurrences
prev_occurrences = aws_cron.get_prev(start_date, n=2)
print(prev_occurrences)
# Output: [datetime.datetime(2023, 11, 15, 12, 0, tzinfo=datetime.timezone.utc),
# datetime.datetime(2023, 10, 15, 12, 0, tzinfo=datetime.timezone.utc)]
Setting inclusive=True
includes the start date in the results if it matches the schedule. The default is False
.
from aws_croniter import AwsCroniter
from datetime import datetime, timezone
# AWS cron expression
cron_expression = "0 12 15 * ? 2023"
aws_cron = AwsCroniter(cron_expression)
# Starting datetime
start_date = datetime(2023, 12, 15, 12, 0,
tzinfo=timezone.utc)
# Include the starting date in the results
prev_occurrence_inclusive = aws_cron.get_prev(start_date, inclusive=True)
print(prev_occurrence_inclusive)
# Output: [datetime.datetime(2023, 12, 15, 12, 0, tzinfo=datetime.timezone.utc)]
The get_all_schedule_bw_dates
method retrieves all occurrences of the cron schedule between two specified dates.
from aws_croniter import AwsCroniter
from datetime import datetime, timezone
# AWS cron expression
cron_expression = "0 12 15 * ? 2023"
aws_cron = AwsCroniter(cron_expression)
# Define the date range
from_date = datetime(2023, 11, 14, tzinfo=timezone.utc)
to_date = datetime(2023, 12, 31, tzinfo=timezone.utc)
# Fetch all occurrences in the range
all_occurrences = aws_cron.get_all_schedule_bw_dates(from_date, to_date)
print(all_occurrences)
# Output: [datetime.datetime(2023, 11, 15, 12, 0, tzinfo=datetime.timezone.utc),
# datetime.datetime(2023, 12, 15, 12, 0, tzinfo=datetime.timezone.utc)]
Setting exclude_ends=True
omits occurrences that match the start and end dates. The default is False
.
from aws_croniter import AwsCroniter
from datetime import datetime, timezone
# AWS cron expression
cron_expression = "0 12 15 * ? 2023"
aws_cron = AwsCroniter(cron_expression)
# Define the date range
from_date = datetime(2023, 11, 14, tzinfo=timezone.utc)
to_date = datetime(2023, 12, 31, tzinfo=timezone.utc)
# Exclude the start and end dates from the results
all_occurrences_exclude_ends = aws_cron.get_all_schedule_bw_dates(from_date, to_date, exclude_ends=True)
print(all_occurrences_exclude_ends)
# Output: [datetime.datetime(2023, 11, 15, 12, 0, tzinfo=datetime.timezone.utc),
# datetime.datetime(2023, 12, 15, 12, 0, tzinfo=datetime.timezone.utc)]
Contributions are welcome! Please read the contributing guidelines first.
This project is licensed under the MIT License. See the LICENSE file for details.
For any questions or suggestions, please open an issue or contact the maintainer at hello@techwithsid.com.