背景
由于工作需要,经常要批量发送邮件,最开始的解决方法是通过Excel的VBA宏+outlook进行发送,但由于平时更多的使用Foxmail,而VBA调用Foxmail的办法至今都没有很好的解决(汗…)并且,很多环境中excel的vba与outlook的环境并不是每台机子都具备,所以萌生了使用Python打包一个邮件批量发送的小程序。
程序功能:
收件人、抄送人、主题、正文以及附件均通过Excel控制,只需要制作好Excel文件,即可批量发送;
使用方法:
- 将主程序与“邮件地址.xlsx"放在同一个文件夹下
- 发送前要核对邮件地址.xlsx中的数据准确性,且不要改动列的顺序。
- 发送完成后,会在当前目录下生成log.txt的文件,记录发送的结果
- 可通过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&