-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathemail_bot.py
More file actions
54 lines (42 loc) · 1.45 KB
/
email_bot.py
File metadata and controls
54 lines (42 loc) · 1.45 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
import pandas as pd
import smtplib
import os
from dotenv import load_dotenv
from email.mime.text import MIMEText
from email.mime.multipart import MIMEMultipart
# Carrega as variáveis do arquivo .env
load_dotenv()
# Função para criar mensagem personalizada
def criar_mensagem(nome, valor, vencimento):
return f"""Olá {nome},
Este é um lembrete do seu pagamento de R$ {valor:.2f}, com vencimento em {vencimento}.
Por favor, entre em contato se tiver dúvidas.
Atenciosamente,
Sua Empresa
"""
# Função para enviar e-mail
def enviar_email(destinatario, assunto, mensagem):
remetente = os.getenv("EMAIL_REMETENTE")
senha = os.getenv("SENHA_DO_APP")
msg = MIMEMultipart()
msg["From"] = remetente
msg["To"] = destinatario
msg["Subject"] = assunto
msg.attach(MIMEText(mensagem, "plain"))
try:
with smtplib.SMTP("smtp.gmail.com", 587) as servidor:
servidor.starttls()
servidor.login(remetente, senha)
servidor.send_message(msg)
print(f"✅ E-mail enviado para: {destinatario}")
except Exception as e:
print(f"❌ Erro ao enviar para {destinatario}: {e}")
# Leitura da planilha e envio
df = pd.read_excel("clientes.xlsx")
for _, row in df.iterrows():
nome = row["Nome"]
email = row["Email"]
valor = row["Valor"]
vencimento = row["Vencimento"]
corpo_email = criar_mensagem(nome, valor, vencimento)
enviar_email(email, "Lembrete de Pagamento", corpo_email)