Automatizar o envio de e-mails personalizados, extraindo os dados requeridos de uma planilha. O exemplo utilizado extraiu nome, e-mail e uma mensagem personalizada de cada pessoa. Para personalizar o corpo do e-mail, utilizamos um arquivo HTML a ser lido pelo código em Python.
-
Para conseguir utilizar esse projeto, é preciso criar uma senha de app no Google após ativar a verificação de dois fatores. Para isso, o seguinte procedimento deve ser feito:
- Ligar a verificação de 2 etapas;
- Criar uma senha de app. Na seleção de apps, escolha outros. Vai aparecer um código em amarelo, copie e salve. Vamos nos referir a esse código como senha daqui pra frente.
-
O envio é realizado através do Gmail. Para enviar de outros provedores, deve-se ir na linha abaixo do código:
with smtplib.SMTP_SSL('smtp.gmail.com', 465, context = safe) as smtp: smtp.login(email_origem, email_senha) smtp.sendmail(email_origem, email_destino, mensagem.as_string())
Substitua os parâmetros smtp.gmail.com e a porta 465 pelos relativos ao provedor que você deseja. Você pode consultar alguns aqui.
-
Este código se baseia na extração de dados de arquivos csv para envios personalizados em massa. O arquivo de e-mail, no entanto, não sofreu estilização, que seria possível utilizando arquivos de HTML/CSS como corpo do texto e abrindo esses arquivos para leitura, dentre outros procedimentos.
-
Para modificar aparência ou informações do corpo do texto, modifique o arquivo HTML.
- As bibiotecas usadas, com exceção da Pandas e da jinja2, já vêm instaladas por padrão nas versões mais recentes de Python.
import smtplib
import ssl
from email.message import EmailMessage
import os
import mimetypes
import pandas as pd
from jinja2 import Template
- Na linha 11 do código, temos uma variável chamada email_senha. Lá que deve ser colocada a senha que criamos nas orientações básicas.
- Para fins de exemplo, vamos utiizar uma planilha chamada nome_arquivo.csv, conforme abaixo:
- Nesse exemplo, o código completo ficaria:
email_senha = 'fkekrnnj3248ndks'
email_origem = '[email protected]'
planilha = pd.read_csv("nome_arquivo.csv")
emails_de_envio = planilha['E-mail'].tolist()
lista_de_nomes = planilha['Nome'].tolist()
feedback = planilha['Feedback'].tolist()
for i in range(0, 2):
email_destino = emails_de_envio[i]
assunto = 'Feedback Individual | teste6'
template = Template(open('corpohtml.txt', 'r').read())
body = template.render(nome=lista_de_nomes[i], feedback_atual = feedback[i])
mensagem = EmailMessage()
mensagem["From"] = email_origem
mensagem["To"] = email_destino
mensagem["Subject"] = assunto
mensagem.set_content(body, subtype='html')
safe = ssl.create_default_context()
with smtplib.SMTP_SSL('smtp.gmail.com', 465, context = safe) as smtp:
smtp.login(email_origem, email_senha)
smtp.sendmail(email_origem, email_destino, mensagem.as_string().encode('utf-8'))
- Os e-mails ficariam no seguinte formato: