Command-line tool to read events from a iCalendar (ICS)
Project description
Command-line tool to read icalendar events
Introduction
This command-line tool allows users to query and filter iCalendar (RFC 5545) calendars. It leverages the excellent recurring-ical-events library for parsing and querying the calendar contents.
Leveraging the powerful jsonargparse library, this tool supports configuration and control via command-line parameters or a JSON configuration file.
Features
- Download and parse iCalendar files
- from remote HTTP URL (
https://<path to icalendar server>) - from local file URL (
file://<abs. path to local ICS file>) - configurable encoding
- from remote HTTP URL (
- Filtering
- by start- and end-date range
- by event summary, description or location text (RegEx match)
- Different Outputs
- Formats: JSON, human-readable (pretty printed)
- Targets: shell (stdout), file
Changelog
Changes can be followed at CHANGELOG.md.
Requirements
- Python 3.9
- pip or pipx
For development:
Setup
With pip / pipx
pip install icalendar-events-cli
pipx install icalendar-events-cli
Setup directly from github repo / clone
git clone https://github.com/waldbaer/icalendar-events-cli.git
cd icalendar-events-cli
python -m venv .venv
source ./.venv/bin/activate
pip install .
Usage
All parameters can be provided either as command-line arguments or through a JSON configuration file (default: config.json).
A combination of both methods is also supported.
A common approach is to define the calendar URL and HTTP authentication credentials in the JSON configuration file, while specifying filters as command-line arguments. Alternatively, you can define all credentials via command-line parameters or include the applied filters directly in the JSON configuration file.
The results of all executed queries are returned in human-readable (pretty-printed) or machine-readable JSON format. This output can be displayed directly on the shell (stdout) or saved to a file.
The machine-readable JSON output format is designed for seamless integration with automation
platforms, such as Node-RED, which typically execute the
icalendar-events-cli tool.
Examples
Example 1: Query Public Holiday Calendar
- Use human-readable output format
- Pass all parameters as command-line arguments
icalendar-events-cli --calendar.url https://www.thunderbird.net/media/caldata/autogen/GermanHolidays.ics \
--filter.start-date $(date +%Y)-01-01T02:00:00+02:00 \
--filter.end-date $(date +%Y)-12-31T02:00:00+01:00 \
--filter.summary ".*(Weihnacht|Oster).*"
Start Date: 2025-01-01T02:00:00+02:00
End Date: 2025-12-31T02:00:00+01:00
Summary Filter: .*(Weihnacht|Oster).*
Number of Events: 3
2025-04-20T00:00:00+02:00 -> 2025-04-20T23:59:59+02:00 [86399 sec] | Ostersonntag (Brandenburg) | Description: Common local holiday - Der Ostersonntag ist laut der christlichen Bibel ein Feiertag in Deutschland, um die Auferstehung Jesu Christi zu feiern.
2025-04-21T00:00:00+02:00 -> 2025-04-21T23:59:59+02:00 [86399 sec] | Ostermontag | Description: Christian - Viele Menschen in Deutschland begehen jährlich den Ostermontag am Tag nach dem Ostersonntag. Es ist in allen Bundesstaaten ein Feiertag.
2025-12-25T00:00:00+01:00 -> 2025-12-25T23:59:59+01:00 [86399 sec] | Weihnachten | Description: Christian - Der Weihnachtstag markiert die Geburt Jesu Christi und ist ein gesetzlicher Feiertag in Deutschland. Es ist jedes Jahr am 25. Dezember.
Example 2: Query School Vacation Calendar
The machine-readable JSON output format is designed for seamless integration with automation platforms, such as Node-RED, which typically execute the icalendar-events-cli tool.
- Use JSON output format++
- Mixed parameter configuration: Pass only end-date as command-line argument.
Create school-summer-vacation.json containing calendar URL, summary filter and output format settings:
{
"calendar" : {
"url" : "https://www.feiertage-deutschland.de/kalender-download/ics/schulferien-baden-wuerttemberg.ics",
"verify_url": true
},
"filter": {
"summary": "Sommer.*"
},
"output": {
"format": "json"
}
}
Query the calendar for summer vacation until end of next year:
icalendar-events-cli --config school-summer-vacation.json --filter.end-date $(($(date +%Y) + 1))-12-31T23:59:59
{
"filter": {
"start-date": "2025-01-25T11:09:20+01:00",
"end-date": "2026-12-31T23:59:59+01:00",
"summary": "Sommer.*"
},
"events": [
{
"start-date": "2025-07-31T00:00:00+02:00",
"end-date": "2025-09-13T23:59:59+02:00",
"summary": "Sommerferien Baden-Württemberg 2025",
"description": "Schulferien 2025: https://www.feiertage-deutschland.de/schulferien/2025/",
"location": "BW"
},
{
"start-date": "2026-07-30T00:00:00+02:00",
"end-date": "2026-09-12T23:59:59+02:00",
"summary": "Sommerferien Baden-Württemberg 2026",
"description": "Schulferien 2026: https://www.feiertage-deutschland.de/schulferien/2026/",
"location": "BW"
}
]
}
All Available Parameters and Configuration Options
Details about all available options:
Usage: icalendar-events-cli [-h] [--version] [-c CONFIG] --calendar.url URL [--calendar.verify-url {true,false}] [--calendar.user USER]
[--calendar.password PASSWORD] [--calendar.encoding ENCODING] [-s START_DATE] [-e END_DATE] [-f SUMMARY]
[--filter.description DESCRIPTION] [--filter.location LOCATION] [--output.format {human_readable,json}] [-o FILE]
Command-line tool to read events from a iCalendar (ICS) files. | Version 1.0.1 | Copyright 2023-2025
Default Config File Locations:
['./config.json'], Note: no existing default config file found.
Options:
-h, --help Show this help message and exit.
--version Print version and exit.
-c, --config CONFIG Path to JSON configuration file.
--calendar.url URL URL of the iCalendar (ICS).
Also URLs to local files with schema file://<absolute path to local file> are supported. (required, type: None)
--calendar.verify-url {true,false}
Configure SSL verification of the URL (type: None, default: True)
--calendar.user USER Username for calendar URL HTTP authentication (basic authentication) (type: None, default: None)
--calendar.password PASSWORD
Password for calendar URL HTTP authentication (basic authentication) (type: None, default: None)
--calendar.encoding ENCODING
Encoding of the calendar (default: UTF-8)
-s, --filter.start-date START_DATE
Start date/time of event filter by time (ISO format). Default: now (type: datetime_isoformat, default: now)
-e, --filter.end-date END_DATE
End date/time of event filter by time (ISO format). Default: end of today (type: datetime_isoformat, default: end of today)
-f, --filter.summary SUMMARY
RegEx to filter calendar events based on the summary attribute. (type: regex_type, default: None)
--filter.description DESCRIPTION
RegEx to filter calendar events based on the description attribute. (type: regex_type, default: None)
--filter.location LOCATION
RegEx to filter calendar events based on the location attribute. (type: regex_type, default: None)
--output.format {human_readable,json}
Output format. (type: None, default: human_readable)
-o, --output.file FILE
Path of JSON output file. If not set the output is written to console / stdout (type: None, default: None)
Development
Setup environment
pdm install --dev
Format / Linter / Tests
# Check code style
pdm run format
# Check linter
pdm run lint
# Run tests
pdm run tests
Publish
# API token will be requested interactively as password
pdm publish -u __token__
# or to test.pypi.org
pdm publish --repository testpypi -u __token__
Acknowledgments
Special thanks to recurring-ical-events for providing the core library that powers this tool.
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file icalendar_events_cli-1.0.1.tar.gz.
File metadata
- Download URL: icalendar_events_cli-1.0.1.tar.gz
- Upload date:
- Size: 22.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: pdm/2.22.4 CPython/3.13.2 Linux/6.13.7-arch1-1
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d5b02d7930e06113fa91e2fcca3b2902f2fad1f39d0ba8231b6fdd5b3d099d9f
|
|
| MD5 |
9ff1b77d0c0902af6c1367d5d69f06b5
|
|
| BLAKE2b-256 |
b59da8309a85cb5970071d411e668d32cac172d8802c36ed4e3d263799572889
|
File details
Details for the file icalendar_events_cli-1.0.1-py3-none-any.whl.
File metadata
- Download URL: icalendar_events_cli-1.0.1-py3-none-any.whl
- Upload date:
- Size: 12.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: pdm/2.22.4 CPython/3.13.2 Linux/6.13.7-arch1-1
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
8c06bf865ea426bf13f68c06599fb1189572b1eee171c21653fc18051bbde673
|
|
| MD5 |
013710fedd8d4a65da829c234896ceee
|
|
| BLAKE2b-256 |
86dc48b47d1fd81f60a9b4a2c936f920dfc8aeeb968e01e5cef6b61cd543dfc6
|