以下为使用python给指定路径的csv表格中的联系人群发带附件的邮件(csv表格的第一列为联系人姓名,第二列为联系人邮箱账号)的代码,详情见注释。
import time
import csv #用于读取收件人列表
import smtplib #用于发送邮件
from email.header import Header #Header用于构造邮件头
from email.mime.text import MIMEText #MIMEText用于构造文本邮件
from email.mime.image import MIMEImage #MIMEImage用于构造图片邮件
from email.mime.multipart import MIMEMultipart #MIMEMultipart用于构造复杂邮件(带附件的邮件)
#收件人信息创建
def receive_info():
# 可以是一个列表,支持多个邮件地址同时发送,测试改成自己的邮箱地址
to_addrs = []
#to = input('请输入收件人邮箱:')
with open('收件人邮箱.csv','r',encoding='utf-8') as f:
reader = csv.reader(f)
try:
for row in reader:
to_addrs.append(row[1])
print('收件人信息读取完毕!')
time.sleep(1)
print('以下为收件人邮箱列表:\n',to_addrs)
receivers = ','.join(to_addrs)
except Exception as e:
print('读取收件人信息失败!原因如下:')
print(e)
return to_addrs,receivers
#发件人信息创建
def send_info():
print('开始输入发件人信息...')
time.sleep(1)
try:
sender_mail = input('请输入发件人邮箱:')
sender_pass = input('请输入发件人邮箱授权码(不要加空格):')#同样是乱打的
smtp_server = 'smtp.qq.com' #邮箱服务器
time.sleep(1)
print('发件人信息录入成功!')
except Exception as e:
print('发件人信息输入失败!以下为失败原因:')
print(e)
return sender_mail,sender_pass,smtp_server
#构造邮件
def mail_body(to):
# 设置总的邮件体对象,对象类型为mixed,可以构造带附件的复杂邮件
msg_root = MIMEMultipart('mixed')
# 邮件添加的头尾信息等
msg_root['From'] = Header(sender_mail)
msg_root['To'] = Header(receivers) #Header的参数不能为列表
# 邮件的主题,显示在接收邮件的预览页面
subject = 'python sendemail test successful'
msg_root['subject'] = Header(subject, 'utf-8') #第一个参数为邮件主题,第二个参数为编码方式
# 构造正文文本内容
text_info = 'hello world'
text_sub = MIMEText(text_info, 'plain', 'utf-8') #第一个参数为文本内容,第二个参数为格式(‘plain'为纯文本,第三个参数为编码方式)
msg_root.attach(text_sub)
# 构造超文本附件
url = "https://blog.csdn.net/m0_45654959"
html_info = """
<p>点击以下链接,你会去向一个更大的世界</p>
<p><a href="%s" rel="external nofollow" >click me</a></p>
<p>i am very galsses for you</p>
"""% url
html_sub = MIMEText(html_info, 'html', 'utf-8') #超文本邮件体
# 如果不加下边这行代码的话,上边的文本是不会正常显示的,会把超文本的内容当做文本显示
html_sub["Content-Disposition"] = 'attachment; filename="csdn.html"' #将超文本邮件体作为附件
# 把构造的内容(超文本附件)写到邮件体中
msg_root.attach(html_sub)
# 构造图片附件
image_file = open(r'D:\Anaconda\programm_my\little_programm\test.gif', 'rb').read()
image = MIMEImage(image_file) #图片邮件体
image.add_header('Content-ID', '<image1>') #将图片在邮件中的目录ID设为<image1>,只有一张图片时此句可以省略
# 如果不加下边这行代码的话,会在收件方方面显示乱码的bin文件,下载之后也不能正常打开
image["Content-Disposition"] = 'attachment; filename="hua_ji.gif"'
#把构造的内容(图片附件)写入邮件体当中
msg_root.attach(image)
# 构造文本附件(base64数据流)
txt_file = open(r'D:\Anaconda\programm_my\little_programm\hello_word.txt', 'rb').read()
txt = MIMEText(txt_file, 'base64', 'utf-8')
txt["Content-Type"] = 'application/octet-stream' #Content-Type默认为application/octet-stream,此句可以不加
#以下代码可以重命名附件为hello_world.txt
txt.add_header('Content-Disposition', 'attachment', filename='hello_world.txt')
#把构造的内容(文本附件)写入邮件体当中
msg_root.attach(txt)
return msg_root
#邮件发送函数
def send_mail():
time.sleep(1)
print('开始发送邮件...')
try:
server =smtplib.SMTP_SSL(smtp_server)#QQ邮箱采用SSL方式加密;仅在python3.7中才需要给smtplib.SMPT_SSL()方法传入发件人邮箱地址参数
server.connect(smtp_server,465)
server.login(sender_mail, sender_pass)
server.sendmail(sender_mail, to_addrs, msg.as_string())
server.quit()
print('恭喜你!邮件发送成功!')
except Exception as e:
print('邮件发送失败!以下为失败原因:')
print(e)
#主函数:
def main():
send_mail()
if __name__ == '__main__':
#初始化收件人、发件人、邮件体数据
to_addrs,receivers = receive_info()
sender_mail,sender_pass,smtp_server = send_info()
msg = mail_body(to_addrs)
#调用主函数,发送邮件
main()
总结
以上所述是小编给大家介绍的python给指定csv表格中的联系人群发邮件,希望对大家有所帮助!