Crie um bot para Telegram e gerencie a escala de plantonistas
O uso de bots em aplicativos de mensagens como o Telegram tem se tornado cada vez mais comum. Eles podem ser utilizados para as mais diversas finalidades, desde tirar dúvidas até realizar tarefas específicas. Neste artigo, apresentaremos um exemplo de bot para o Telegram que permite o cadastro e consulta de plantonistas.
[ Hits: 3.379 ]
Por: Leonardo Berbert Gomes em 04/04/2023 | Blog: https://www.linkedin.com/in/leoberbert
import logging import sqlite3 from datetime import datetime from telegram.ext import Updater, CommandHandler, MessageHandler, filters # Habilitar logs de erro logging.basicConfig(format='%(asctime)s - %(name)s - %(levelname)s - %(message)s', level=logging.ERROR) # Definir o token de acesso do bot TOKEN = "seu_token_aqui" def plantonista_do_dia(update, context): # Obter a data atual hoje = datetime.today().strftime('%Y-%m-%d') # Conectar ao banco de dados conn = sqlite3.connect('plantao.db') # Consultar o plantonista do dia cursor = conn.execute("SELECT plantonista FROM plantao WHERE data=?", (hoje,)) plantonistas = cursor.fetchall() if len(plantonistas) > 0: # Enviar mensagem com o nome do plantonista plantonista = plantonistas[0][0] context.bot.send_message(chat_id=update.effective_chat.id, text=f"O plantonista de hoje é {plantonista}.") else: # Enviar mensagem informando que não há plantonista cadastrado para hoje context.bot.send_message(chat_id=update.effective_chat.id, text="Não há plantonista cadastrado para hoje.") # Fechar a conexão com o banco de dados conn.close() # Definir o comando de ajuda def ajuda(update, context): # Mensagem de ajuda ajuda_texto = "Comandos disponíveis: /plantonista - Mostrar o plantonista do dia /ajuda - Mostrar esta mensagem de ajuda " # Enviar a mensagem de ajuda para o grupo context.bot.send_message(chat_id=update.effective_chat.id, text=ajuda_texto) # Configurar o bot e os handlers de comandos e mensagens updater = Updater(token=TOKEN, use_context=True) dispatcher = updater.dispatcher dispatcher.add_handler(CommandHandler('plantonista', plantonista_do_dia)) dispatcher.add_handler(CommandHandler('ajuda', ajuda)) # Iniciar o bot updater.start_polling() # Mantém o bot em execução updater.idle() # Termina o bot updater.stop()
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>Cadastro de Plantonista - Sucesso</title> <style> /* Adicione aqui o CSS solicitado */ body { background-color: #F5F5F5; font-family: Arial, sans-serif; } .container { width: 80%; margin: 0 auto; text-align: center; margin-top: 50px; } .card { background-color: #FFFFFF; border-radius: 8px; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1); padding: 30px; margin-bottom: 20px; text-align: center; } h1 { font-size: 32px; margin-top: 0; } p { font-size: 18px; margin-top: 20px; margin-bottom: 20px; } button { font-size: 18px; padding: 10px 30px; background-color: #008CBA; color: #FFFFFF; border: none; border-radius: 4px; cursor: pointer; } </style> </head> <body> <div class="container"> <div class="card"> <h1>Cadastro realizado com sucesso!</h1> <p>Plantonista {{ plantonista }} cadastrado para a data {{ data }}</p> <a href="{{ url_for('cadastro_plantonista') }}"><button>Voltar</button></a> </div> </div> </body> </html>
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>Cadastro de Plantonista</title> <style> body { background-color: #fff; color: #333; font-family: Arial, sans-serif; font-size: 16px; line-height: 1.5; margin: 0; padding: 0; } h1 { color: #0072c6; font-size: 2.5em; margin-top: 70px; margin-bottom: 20px; text-align: center; } form { background-color: #f2f2f2; border-radius: 10px; margin: 20px auto; padding: 20px; max-width: 400px; } label { display: block; font-weight: bold; margin-bottom: 10px; } input[type="text"], input[type="date"] { border: none; border-radius: 5px; font-size: 1em; padding: 10px; width: 100%; } input[type="submit"] { background-color: #0072c6; border: none; border-radius: 5px; color: #fff; cursor: pointer; font-size: 1em; margin-top: 20px; padding: 10px; transition: background-color 0.3s ease; width: 100%; } input[type="submit"]:hover { background-color: #005b9e; } </style> </head> <body> <h1>Cadastro de Plantonista</h1> <form action="/plantao" method="POST"> <label for="plantonista">Plantonista:</label> <input type="text" name="plantonista" id="plantonista"><br><br> <label for="data">Data:</label> <input type="date" name="data" id="data" pattern="d{4}-d{2}-d{2}"><br><br> <input type="submit" value="Cadastrar"> </form> </body> </html>
SuperDNS: Solução definitiva para DNS dinâmico
Detectando vulnerabilidades com o Nessus
Gerando gráficos sem mistérios no MRTG (Debian)
Scikit Learn: Projetando o futuro de suas APIs e aplicativos usando machine learning
Monitorando a saúde do Apache (Prometheus + Grafana)
Python - Enviando Backup para Servidor Secundário
PEP 8 - Guia de estilo para código Python
Python - Uma linguagem orientada a objetos
Esteganografia e Esteganálise: transmissão e detecção de informações ocultas em imagens digitais
Como gerar qualquer emoji ou símbolo unicode a partir do seu teclado
Atualizando o Passado: Linux no Lenovo G460 em 2025
aaPanel - Um Painel de Hospedagem Gratuito e Poderoso
O macete do Warsaw no Linux Mint e cia
Visualizar arquivos em formato markdown (ex.: README.md) pelo terminal
Dando - teoricamente - um gás no Gnome-Shell do Arch Linux
Como instalar o Google Cloud CLI no Ubuntu/Debian
Mantenha seu Sistema Leve e Rápido com a Limpeza do APT!
Procurando vídeos de YouTube pelo terminal e assistindo via mpv (2025)
Mikrotik não abre o webmail-segur... da Locaweb (10)
Instalação de Ubuntu em SSD (interno) como se fosse um dispositivo ext... (0)