11月会员限时半价,下个月恢复原价188 开会员立即查看此资源以及本站全部资源,人工开通或售后问题加v:thumbxmw
详情点击这里查看
本文旨在解决作者在日常工作中遇到的发送邮件附件的几种场景应用问题:
为解决上述问题189邮箱后缀,采用windows10+python.8+smtplib利用smtp方式发送邮件。
实现:
准备工作:(参考如下对应创建好目录和文本,准备好附件文件189邮箱后缀,可按需准备)
(文件夹内容截图)
邮件收件人文本内容 注意,号是在英文状态下输入,
邮件正文内容 可根据需要自定义输入
群发附件目录下多种格式文件并存
代码编辑状态
功能一:采用收件人姓名作为关键字,匹配附件中文件名称,如果有就发送匹配文件
输入y 则根据收件人姓名作为关键字对应发送带关键字名的附件内容
关键字匹配邮件效果1
关键字匹配邮件效果2
功能二:将制定附件目录下的所有文件全部发送给多个不同的收件人
用户输入N系统开始发送邮件
同一附件发送给多个不同的邮件人效果1
同一附件发送给多个不同的邮件人效果2
【注意】py文件、邮件正文、邮件收件人须在同一个目录下,如本文d:群发邮件带附件。
【扩展】
同一附件多人发送.py 源代码如下:
from smtplib import SMTP #邮件
from email.mime.multipart import MIMEMultipart #邮件类型
from email.mime.text import MIMEText
from email.mime.base import MIMEBase #附件
from email import encoders #转码
from email.header import make_header
import os #文件操作
import traceback
def 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_dict
def 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_content
def 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("按回车键退出!")
限 时 特 惠: 本站每日持续更新海量各大内部创业教程,加站长微信免费获取积分,会员只需38元,全站资源免费下载 点击查看详情
站 长 微 信: thumbxmw
声明:本站内容转载于网络,版权归原作者所有,仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任,若侵犯到你的版权利益,请联系我们,会尽快给予删除处理!