Dynamic task scheduler
Project description
ClockParts
Hi There 👋!
I'm the developer of ClockParts. I encountered many challenges when working with scheduling tasks in Python, whether in multi-threading projects, APIs, or microservices. So, I created ClockParts to address these issues. It's simple, compatible with asynchronous operations and threads, and human-readable, making scheduling in Python easier and more efficient.
Installation
It's very easy on PyPI:
pip install ClockParts
Usage
This usage is very simple and based on Shaft and Cog. Shaft is the manager of Cog, and Cog represents your tasks.
Project structure:
├── cogs
│ └── my_cogs.py
├── main.py
Shaft
Now, let's see how to create a Shaft:
# main.py
from ClockParts import Shaft
import asyncio
shaft = Shaft()
if __name__ == "__main__":
# Create a new Shaft
shaft = Shaft()
# Add the "cogs" folder (by default it's "cogs")
shaft.add_cogs("cogs")
# Run the Shaft
asyncio.run(shaft.run())
It's simple! Basically, you need an asynchronous context in your project. If you need an internal explanation, in short, it checks every second if there is a new Cog Task to execute.
Cogs
Let's move on to your Cogs!
# cogs/my_cogs.py
from ClockParts import Cog
from datetime import timedelta
class MyCog(Cog):
"""Examples of Cog usage"""
@Cog.task(timedelta(seconds=5))
async def task1(self):
"""
Task to run every after 5 seconds (using timedelta)
"""
print("Executing task 1")
@Cog.task("11:00")
async def task2(self):
"""
Task to be performed every day at 11:00
"""
print("Executing task 2")
@Cog.task("thu 10:00")
async def task3(self):
"""
Task to be executed every Thursday at 10:00
"""
print("Executing task 3")
@Cog.task("1m 10:00")
async def task4(self):
"""
Task to be executed every month at 10:00
"""
print("Executing task 4")
@Cog.task("mon 10:00")
async def task5(self):
"""
Task to be executed every Monday at 10:00
"""
print("Executing task 5")
Does it look simple? Yes, indeed! In short, you don't need to import ClockParts, just import Cog and use its methods to schedule tasks. There are two ways to schedule your tasks:
- String format: Ideal for selecting specific days of the week and month.
- Timedelta format: Ideal for scheduling tasks at specific times. In most cases, you should use timedelta. Your Cogs are ready! To run your Shaft, you just need to execute main.py, and you're good to go!
If you're contributing to the repository, feel free to open an issue, pull request, or fork. You're welcome!
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 clockparts-0.1.52.tar.gz
.
File metadata
- Download URL: clockparts-0.1.52.tar.gz
- Upload date:
- Size: 20.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.8.4 CPython/3.13.0 Windows/11
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 600ec48520b1caf228cee9a2f413d8f42cf3f7bb7e0481cae2258dfcd6aa71ef |
|
MD5 | 5d29ccc1faba62374883b8a5f11a0e69 |
|
BLAKE2b-256 | 9d99cc678ad0d77b9d67790fd9c2533dbb633fdbdf7ac3500aae3812f326cdc5 |
File details
Details for the file clockparts-0.1.52-py3-none-any.whl
.
File metadata
- Download URL: clockparts-0.1.52-py3-none-any.whl
- Upload date:
- Size: 21.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.8.4 CPython/3.13.0 Windows/11
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | cfe097479e7338ec502e864b6a30b3f0e1a58e1a8d98bded4c9df40bbe59bd8f |
|
MD5 | a1aae337275349440c94e3ad85920cd4 |
|
BLAKE2b-256 | 864056a6f56c0bea2e568688869cf0de3022cb52f6419cab9b6f82ad34aef211 |