前言:
现在你们对“python邮件群发”都比较重视,各位老铁们都需要知道一些“python邮件群发”的相关资讯。那么小编在网上搜集了一些有关“python邮件群发””的相关文章,希望姐妹们能喜欢,姐妹们一起来学习一下吧!本文旨在解决作者在日常工作中遇到的发送邮件附件的几种场景应用问题:
1、在新闻稿件外宣时,同一个稿件要作为附件内容,需要单独发送给多个新媒体平台收件人,且又不便于在邮件页面采取一次性发送多个联系人的方式进行邮件推送。(解决办法:同一个稿件快速批量自动化传送到多个收件人邮箱)2、在某些特定场合下,需要将不同的附件文件发送给指定的用户邮箱里,如张三的工资条,就只能发给张三。(解决办法:关键字匹配发送特定附件内容到特定收件人邮箱)3、其它特定场景的邮件一对多发送等问题
为解决上述问题,采用windows10+python.8+smtplib利用smtp方式发送邮件。
实现:
1、支持163网易、qq等邮件系统;2、用户可自定义选择是按关键字发送附件还是全部附件发送;3、关键字搜索,以发件人姓名(作key)在附件文件夹中没有类似关键字文件,就直接跳过,如果有类似的就将对应的文件作为附件发送给该收件人;4、附件支持各种附件,不局限于jpg图片,理论上支持任何格式文件作为附件上传;5、支持同时一份附件发给多个人,且邮件地址采用文本方式存储。6、用户可快速添加邮件人列表和自定义邮件正文内容。
准备工作:(参考如下对应创建好目录和文本,准备好附件文件,可按需准备)
功能一:采用收件人姓名作为关键字,匹配附件中文件名称,如果有就发送匹配文件
功能二:将制定附件目录下的所有文件全部发送给多个不同的收件人
【注意】py文件、邮件正文、邮件收件人须在同一个目录下,如本文d:\群发邮件带附件。
【扩展】
为了更直观的体验,建议使用python tkinter构建图形化操作;对已经发送过的附件,建议邮件发送完毕后,将附件已送到别的目录下进行保存备用,也可直接删除,需要的时候可以直接在邮件里面去下载保存使用。
同一附件多人发送.py 源代码如下:
from smtplib import SMTP #邮件from email.mime.multipart import MIMEMultipart #邮件类型from email.mime.text import MIMETextfrom email.mime.base import MIMEBase #附件from email import encoders #转码from email.header import make_headerimport os #文件操作import tracebackdef get_receiver(): '''读取收件人列表,以{'a': ['a@189.cn', 'a@qq.com'], 'b': ['b@163.com']}的字典形态返回''' receiver_dict = {} with open('邮件收件人.txt', 'r',encoding='UTF-8-sig') as contacts_file: #打印结果会出现 \ufeff, 把 UTF-8 编码 改成 UTF-8-sig for a_contact in contacts_file: temp_address_list = [] a_contact_list = a_contact.split(',') name = a_contact_list[0].strip() for temp_address in a_contact_list[1:]: temp_address_list.append(temp_address.strip()) receiver_dict[name] = temp_address_list return receiver_dictdef read_body(filename): '''导入邮件正文的内容''' with open(filename, 'r',encoding='utf-8') as body_file: #打印结果会出现 \ufeff, 把 UTF-8 编码 改成 UTF-8-sig body_file_content = body_file.read() return body_file_contentdef put_attachment(file_name, msg): '''添加附件''' part = MIMEBase('attachment', 'octet-stream') file_route = attach_file + '\\' + file_name part.set_payload(open(file_route, 'rb').read()) encoders.encode_base64(part) part.add_header('Content-Disposition', 'attachment', filename="%s" % make_header([(file_name, 'UTF-8')]).encode('UTF-8')) #显示中文附件的话选这个 msg.attach(part)#发件人邮箱和密码try: MY_ADDRESS = 'cnsj@163.com' #发件人邮箱 myPass = 'CKOR' #发件人邮箱smtp密码,非web邮箱登录密码 server = SMTP('smtp.163.com') sender_name='瓮县' server.starttls() server.login(MY_ADDRESS, myPass) #利用os获取文件项目所在的路径,并根据该位置对应获取邮件正文、邮件收件人等文件内容 path_this_file = os.path.abspath('.') + "\\" #获取邮件正文 email_body = read_body('邮件正文.txt') print('>>>获取邮件正文成功!') #获取收件人列表 receiver_dict = get_receiver() print('>>>获取收件人列表成功!') print(get_receiver()) #打印结果会出现 \ufeff, 把 UTF-8 编码 改成 UTF-8-sig #获取附件列表 #附件文件所在的目录和文件夹名称"群发附件",请根据需要自行修改 attach_file = path_this_file + '群发附件' attach_list = os.listdir(attach_file) print('>>>获取附件列表成功!') print(attach_file) print(attach_list) #用户选择是否用关键字判断附件并发送邮件 sf=input('是否以收件人为关键字筛选发送附件?请输入Y或N,然后回车运行:') #如果想默认自动运行,无需用户输入y或n,请自行根据需要设定如下其中之一即可 #sf=y #或sy=n for key, value in receiver_dict.items(): msg = MIMEMultipart() #MIME邮件中各种不同类型的内容是分段存储的, #各个段的排列方式、位置信息都通过Content-Type域的multipart类型来定义。 #multipart类型主要有三种子类型:mixed、alternative、related。 msg['From'] = MY_ADDRESS receivers = ','.join(value) msg['To'] = receivers temp_pic_list = [] #如果选择y那就需要以收件人名字为关键字查找当前附件文件中的名称有收件人名字的内容,然后上传对应匹配的文件作为附件 if sf=='Y' or sf=='y': #定义pic1值为空 pic1='' for pic in attach_list: if key in pic: pic1 += format('{'+ pic + '}') put_attachment(pic, msg) temp_pic_list.append(pic) if sf=='N' or sf=='n': pic1='' #如果输入n则不按邮件人名进行附件文件名称是否有邮件人名称的关键字,也就是上传所有附件文件作为附件 for pic in attach_list: pic1 += format('{'+ pic + '}') put_attachment(pic, msg) temp_pic_list.append(pic) if temp_pic_list: #print(pic1) #定义邮件主题 msg['Subject'] = key + '你好:请查收来自【'+ sender_name +'】的邮件并下载附件【' + pic1 +'】' print(msg['Subject']) #msg.attach(MIMEText(email_body, 'html', 'utf-8')) msg.attach(MIMEText(email_body)) server.send_message(msg) print('>>>{}邮件发送成功!'.format(key)) else: print('>>>{}因无附件,没有发送!'.format(key)) server.quit() print('>>>所有邮件均已发送成功!')except: traceback.print_exc()finally: a = input("按回车键退出!")
标签: #python邮件群发