Skip to content

The code allows sending personalized bulk emails with Python, extracting data from a spreadsheet using Pandas. To customize the email body, an HTML file is used.

Notifications You must be signed in to change notification settings

duartebianca/python-email-automation

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

15 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Envio de E-mails com Python

🎯 Objetivo do Projeto

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.

📌 Orientações básicas

  • 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.

✨ Exemplo de Uso

  • 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: image
  • 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:

About

The code allows sending personalized bulk emails with Python, extracting data from a spreadsheet using Pandas. To customize the email body, an HTML file is used.

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages