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.828 ]
Por: Leonardo Berbert Gomes em 04/04/2023 | Blog: https://www.linkedin.com/in/leoberbert
import sqlite3
# Conectar ao banco de dados
conn = sqlite3.connect('plantao.db')
# Criar uma tabela chamada plantao
conn.execute('''
CREATE TABLE plantao (
plantonista TEXT,
data TEXT
);
''')
# Fechar a conexão com o banco de dados
conn.close()
from flask import Flask, render_template, request, redirect, url_for
from flask_httpauth import HTTPBasicAuth
import sqlite3
import logging
log = logging.getLogger('werkzeug')
log.setLevel(logging.ERROR)
app = Flask(__name__)
auth = HTTPBasicAuth()
# Define o caminho para o banco de dados
DB_PATH = 'plantao.db'
# Dicionário com os usuários e senhas
USERS = {
"plantonista": "guarana"
}
# Função que verifica se um usuário está autorizado
@auth.verify_password
def verify(username, password):
if not (username and password):
return False
return USERS.get(username) == password
@app.route('/plantao', methods=['GET', 'POST'])
@auth.login_required
def cadastro_plantonista():
if request.method == 'POST':
plantonista = request.form['plantonista']
data = request.form['data']
# Conecta ao banco de dados
conn = sqlite3.connect(DB_PATH)
# Insere os dados na tabela "plantao"
cur = conn.cursor()
cur.execute("INSERT INTO plantao (plantonista, data) VALUES (?, ?)", (plantonista, data))
conn.commit()
# Fecha a conexão com o banco de dados
conn.close()
# Redireciona para a página de confirmação
return redirect(url_for('cadastro_sucesso', plantonista=plantonista, data=data))
return render_template('index.html')
@app.route('/cadastro_sucesso')
def cadastro_sucesso():
plantonista = request.args.get('plantonista')
data = request.args.get('data')
return render_template('cadastro_sucesso.html', plantonista=plantonista, data=data)
if __name__ == '__main__':
app.run(host='0.0.0.0',debug=True,port=5000)
import sqlite3
# Estabelecendo conexão com o banco de dados
conn = sqlite3.connect('plantao.db')
# Criando um cursor para executar comandos SQL
cursor = conn.cursor()
# Executando uma consulta SELECT em uma tabela
cursor.execute("SELECT * FROM plantao")
# Obtendo todos os resultados da consulta
resultados = cursor.fetchall()
# Imprimindo os resultados na tela
for linha in resultados:
print(linha)
# Fechando a conexão com o banco de dados
conn.close()
Monitoramento de Comunicação - Blackbox Exporter(ICMP) + Prometheus + Grafana
SuperDNS: Solução definitiva para DNS dinâmico
Instalando Apache, PHP e PostgreSQL no Slackware 12 (compilando)
Scikit Learn: Projetando o futuro de suas APIs e aplicativos usando machine learning
Qu1cksc0pe - All-in-One Static Malware Analysis Tool
Python - Uma linguagem orientada a objetos
ISO8583py - Utilizando Python para o tratamento de mensagens ISO8583
Gerar senhas seguras com Python
Cirurgia para acelerar o openSUSE em HD externo via USB
Void Server como Domain Control
Modo Simples de Baixar e Usar o bash-completion
Monitorando o Preço do Bitcoin ou sua Cripto Favorita em Tempo Real com um Widget Flutuante
Como impedir exclusão de arquivos por outros usuários no (Linux)
Cirurgia no Linux Mint em HD Externo via USB
Anúncio do meu script de Pós-Instalação do Ubuntu
Alguém executou um rm e quase mata a Pixar! (4)
Formas seguras de instalar Debian Sid (2)
Duas Pasta Pessoal Aparecendo no Ubuntu 24.04.3 LTS (12)
Alguém pode me indicar um designer freelancer? [RESOLVIDO] (5)
Por que passar nas disciplinas da faculdade é ruim e ser reprovado é b... (6)









