A pure-python calendar queue and library for scheduling events with asyncio.
Many other libraries allow for event/job scheduling but either they are not asynchronous or they are just fire-and-forget.
calendar-queue has two purposes:
- providing the primitives for creating your own scheduler by exporting a
CalendarQueueclass in which events can be awaited - providing a higher level abstraction
Calendarclass that simplifies the usage ofCalendarQueue.
Depending on your needs, you can use one of the two to develop your own event manager/scheduler.
The idea is: we take care of emitting events at the right time, you write the logic for acting accordingly.
pip install calendar-queueA minimal, practical example showing how Calendar can schedule and emit events: schedule three reminders a few seconds apart and consume them as they fire.
import asyncio
from datetime import datetime, timedelta
from calendar_queue import Calendar
calendar = Calendar()
async def producer():
for i in range(1, 4):
when = datetime.now() + timedelta(seconds=i * 2)
calendar.schedule(f"Reminder {i}", when=when)
print(f"scheduled Reminder {i} for {when.isoformat()}")
await asyncio.sleep(0.1)
async def consumer():
async for ts, event in calendar:
print(f"{datetime.fromtimestamp(ts).isoformat()}: {event}")
# stop after the last event
if event == "Reminder 3":
calendar.stop()
async def main():
await asyncio.gather(producer(), consumer())
if __name__ == "__main__":
asyncio.run(main())For more examples and the API reference, see the documentation in the docs folder:
- Tutorials: docs/tutorials
- API reference: docs/api-reference
This library is developed using Python 3.11 and pdm as dependency manager.
Testing is done via github actions and it's done on python versions 3.10, 3.11, 3.12, 3.13, 3.14, 3.14t and on latest ubuntu, macos, windows OSes.
For local development you'll need to have pdm installed, then you can:
- run
pdm installto create the virtual environment and install the dependencies - run
pdm venv activateto activate the virtual environment - run the tests using
pytest - run the linter
pylint src
Contributions are welcome! Especially for new tests and for improving documentation and examples.
The code in this project is released under the MIT License.