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: 2.879 ]
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()
Instalando Apache, PHP e PostgreSQL no Slackware 12 (compilando)
Monitoramento de Comunicação - Blackbox Exporter(ICMP) + Prometheus + Grafana
Scikit Learn: Projetando o futuro de suas APIs e aplicativos usando machine learning
Solucionando problemas no sistema de arquivos
Monitorando a saúde do Apache (Prometheus + Grafana)
Gerar Códigos QRCode com Python
Embutindo imagens nos scripts Python para aplicações Tkinter
Desenvolvendo aplicações GUI simples em Python & Glade (PyGTK) com banco de dados SQLite
Gerar senhas seguras com Python
Compartilhando a tela do Computador no Celular via Deskreen
Como Configurar um Túnel SSH Reverso para Acessar Sua Máquina Local a Partir de uma Máquina Remota
Configuração para desligamento automatizado de Computadores em um Ambiente Comercial
Como renomear arquivos de letras maiúsculas para minúsculas
Imprimindo no formato livreto no Linux
Vim - incrementando números em substituição
Efeito "livro" em arquivos PDF
Como resolver o erro no CUPS: Unable to get list of printer drivers
Melhores Práticas de Nomenclatura: Pastas, Arquivos e Código [RESOLVID... (4)
[Python] Automação de scan de vulnerabilidades
[Python] Script para analise de superficie de ataque
[Shell Script] Novo script para redimensionar, rotacionar, converter e espelhar arquivos de imagem
[Shell Script] Iniciador de DOOM (DSDA-DOOM, Doom Retro ou Woof!)
[Shell Script] Script para adicionar bordas às imagens de uma pasta