python-logo

Formatando e adicionando anexos a e-mails no Python

Há algumas semanas, nós mostramos como enviar e-mail pelo Python usando o módulo smtplib. Hoje iremos dar continuidade ao envio de e-mail, desta vez focaremos em sua formatação e adição de arquivos anexos.

Para fazer este serviço iremos utilizar o módulo email. Este módulo é uma biblioteca para manipulação de mensagens de email e outros documentos do tipo MIME. Como este módulo já está incluso nas bibliotecas do Python você não precisará instalar nenhuma biblioteca adicional.

Submódulos

Antes de iniciar, vamos ver os submódulos do módulo email que iremos utilizar:

from email import encoders

Útil para quando criamos um payload que não seja um já implementado. Neste caso necessitamos codificar a mensagem.

from email.mime.base import MIMEBase

Classe base para quando desejamos enviar um arquivo não suportado pelas classes já disponíveis. Um exemplo é o envio de aquivos de vídeos.

from email.mime.multipart import MIMEMultipart

Usado para criar uma mensagem MIME multpart.

from email.mime.audio import MIMEAudio

Usado para criar objetos MIME para a maior parte de aquivos de áudio.

from email.mime.image import MIMEImage

Usado para criar objetos MIME para a maior parte de aquivos de imagem.

from email.mime.text import MIMEText

Usado para criar objetos MIME para a maior parte de aquivos de texto.

Usando os submódulos

Agora vamos verificar como criar uma mensagem com cada um desses tipos:

MIMEBase

with open('arquivo.zip', 'rb') as f:
mime = MIMEBase('application', 'zip')
mime.set_payload(f.read())

encoders.encode_base64(mime)

MIMEMultipart

msg = MIMEMultipart()
msg.attach(arquivo_mime_1)
msg.attach(arquivo_mime_2)

arquivo_mime deve ser outro subtipo MIME, por exemplo MIMEAudio.

MIMEAudio

with open('audio.ogg', 'rb') as f:
mime = MIMEAudio(f.read(), _subtype='ogg')

MIMEImage

with open('imagem.png', 'rb') as f:
mime = MIMEImage(f.read(), _subtype='png')

MIMEText

with open('pagina.html') as f:
mime = MIMEText(f.read(), _subtype='html')

Adicionando os dados de envio e recebimento no cabeçalho da mensagem:

msg = MIMEText('Exemplo.', 'plain')
msg['From'] = 'seuemail@seudominio.com'
msg['To'] = ', '.join(['outroemail@seudominio.com'])
msg['Cc'] = ', '.join(['emailemcopia@seudominio.com'])
msg['Bcc'] = ', '.join(['emailocultol@seudominio.com'])
msg['Reply-To'] = ', '.join(['seuemail@seudominio.com'])
msg['Subject'] = 'Assunto'
  • O From indica quem está enviando mensagem.
  • O To indica quem irá receber.
  • O Cc indica quem receberá uma cópia deste email.
  • O Bcc também indica quem receberá uma cópia do email, mas as demais pessoas não irão ver o email dele na lista dos enviados.
  • O Reply-To indica para quem será respondido o email.
  • O Subject é o assunto do email.

Para enviar os objetos MIME via SMTP devemos gerar as mensagens no formato raw, para isto utilizamos o método as_string.

Exemplos

Agora que já possuímos uma noção básica do funcionamento do módulo email, vamos criar um exemplo completo utilizando tudo o que foi visto.

O exemplo abaixo exemplifica o envio de um email HTML:

O exemplo abaixo exemplifica o envio de um email HTML com anexo:

Comparando este tutoria ao anterior, a montagem e o envio de um email ficam bem mais simplificados com esta biblioteca para manipulação de email, não é?

Espero que você tenha gostado. Não deixe de assinar nosso feed.

Parte deste código foi obtido na documentação do módulo email.