Send telegram notifications
Project description
What is this?
Super fast (<5min setup) telegram notifications for task-completion, task progress, errors and more. This is an minimal module; no pip dependencies at all.
How do I use this?
-
pip install telepy_notify
-
Take 30sec to get a token:
- open up a chat with https://t.me/botfather
- send
/newbot
to ^ - copy the token out of the response message
-
DM your bot to initialize it (important!)
-
Use it
from telepy_notify import Notifier
#
# setup
#
notify = Notifier(
# read from file
token_path="some/file/thats/git/ignored/telegram.token",
# # OR read from ENV var, ex:
# token_env_var="TELEGRAM_TOKEN",
# # OR give the token directly, ex:
# token="alkdsfjakjfoirj029294ijfoi24j4-2",
# optional: prefix give all messages
message_prefix="Lambda Machine: Experiment 19:",
# optional: set to true when debugging
disable=False,
)
# NOTE:
# other people can run your code without setting up a bot
# because telepy will NEVER throw errors
# if a notification fails, or if a token is bad
# it will intentionally only print warnings instead of
# crashing whatever long-running process you have
#
# Basic notification
#
notify.send("Howdy!")
notify.send("Howdy! <b>I'm bold</b>")
notify.send("Howdy! <b>I'm bold</b>\n<code>thing = [1,3,4]</code>")
#
# get duration and/or error information
#
with notify.when_done:
blah_blah_blah = 10
for blah in range(blah_blah_blah):
from time import sleep
sleep(0.1)
raise Exception(f'''Hello Telegram :)''')
# """
# process took: 1sec, ended at: Sun Aug 20 11:23:38 2023 however it ended with an error: Exception('Hello Telegram :)')
# """
#
# Progress notifications
#
# - gives ETA and other time-info
# - can limit print-rate (by time passed or percent-progress)
# e.g. percent_per_print=50 => message me after 50% progress
# e.g. seconds_per_print=60*30 => message once every 30min
for progress, epoch in notify.progress(range(100), percent_per_print=50, seconds_per_print=60*30):
index = progress.index
# do stuff
import random
accuracy = random.random()
if accuracy > 0.99:
notify.send("Gottem 🎉🎉🎉")
# end do stuff
progress.message = f"recent accuracy: <code>{accuracy}</code>"
# that^ outputs:
# message1:
# [=================>.................] 50.00%
# | 50/100
# | remaining: 0sec
# | eta: 11:52:48
# | elapsed: 0sec
# | recent accuracy: 0.5086382690344122
# message2:
# Done in 1sec at 11:52:49
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
telepy_notify-0.1.0.tar.gz
(8.5 MB
view details)
Built Distribution
telepy_notify-0.1.0-py3-none-any.whl
(237.7 kB
view details)
File details
Details for the file telepy_notify-0.1.0.tar.gz
.
File metadata
- Download URL: telepy_notify-0.1.0.tar.gz
- Upload date:
- Size: 8.5 MB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.4.1 importlib_metadata/6.6.0 pkginfo/1.9.6 requests/2.30.0 requests-toolbelt/1.0.0 tqdm/4.65.0 CPython/3.8.13
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 26ab90a200102a6afcb07b816b23508994acc967072a1f584e608083874c5219 |
|
MD5 | 57e36bdf608f3ef9680f5e8dc158e702 |
|
BLAKE2b-256 | 565ddd67eca4549a0ff6ca660009f320d731348477dfa4b93412d4ff8775bc68 |
File details
Details for the file telepy_notify-0.1.0-py3-none-any.whl
.
File metadata
- Download URL: telepy_notify-0.1.0-py3-none-any.whl
- Upload date:
- Size: 237.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.4.1 importlib_metadata/6.6.0 pkginfo/1.9.6 requests/2.30.0 requests-toolbelt/1.0.0 tqdm/4.65.0 CPython/3.8.13
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | a38cd91b1dc03542f46cc8d2b1434465f561d3c4615ff07a199de45db5cacf45 |
|
MD5 | e56645fba397e5b3bd56d4f20efab4e7 |
|
BLAKE2b-256 | 897a9c5c853d85bbdd0592ca1e145573b1b9f4036fabc7d39da8d9e394485682 |