使用Python进行邮件的批量发送(从Excel读取收件人、主题、正文、附件地址等)

背景

由于工作需要,经常要批量发送邮件,最开始的解决方法是通过Excel的VBA宏+outlook进行发送,但由于平时更多的使用Foxmail,而VBA调用Foxmail的办法至今都没有很好的解决(汗…)并且,很多环境中excel的vba与outlook的环境并不是每台机子都具备,所以萌生了使用Python打包一个邮件批量发送的小程序。

程序功能:

收件人、抄送人、主题、正文以及附件均通过Excel控制,只需要制作好Excel文件,即可批量发送;

使用方法:
  1. 将主程序与“邮件地址.xlsx"放在同一个文件夹下
  2. 发送前要核对邮件地址.xlsx中的数据准确性,且不要改动列的顺序。
  3. 发送完成后,会在当前目录下生成log.txt的文件,记录发送的结果
  4. 可通过pyinstaller方法,将Python文件进行打包,方便多种环境(Windows)使用。
    邮件地址.xlsx的格式如下:
    在这里插入图片描述
源码如下:
import os
import smtplib
import datetime
from email import encoders
from email.header import Header  # 用来设置邮件头和邮件主题
from email.mime.base import MIMEBase
from email.mime.multipart import MIMEMultipart
from email.mime.text import MIMEText
import pandas as pd

def addAttch(attach_file):
    att = MIMEBase('application', 'octet-stream')  # 这两个参数不知道啥意思,二进制流文件
    att.set_payload(open(attach_file, 'rb').read())
    # att.add_header('Content-Disposition&
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值