python如何批量下载邮箱全部附件_python批量发送邮件(文本+excel附件)

本文介绍如何使用Python连接邮箱并批量发送带有Excel附件的邮件。通过smtplib、email等库,实现邮件正文、附件的创建,以及邮箱登陆和邮件发送功能。
摘要由CSDN通过智能技术生成

最近由于工作需要,经常要从一张汇总表中筛选出各组的数据,然后分别点对点发送至各业务方。粘贴复制耗时又心累,遇上有背景格式的还能转半天圈圈,哭唧唧o(╥﹏╥)o。因此尝试python连接邮箱后,从本地读取excel文件后自动发送。需要用到的包有smtplib、email

一、主要步骤

分三块,邮件主体;邮箱登陆;收件人、抄送人发送邮件。

#载入需要的包

import smtplib

from email.mime.text import MIMEText

from email.mime.multipart import MIMEMultipart

1、邮件主体

包含邮件正文 + excel附件

def main_email(text,xlsx_path,xlsx_name):

'''

*text->str: 要发送的邮件正文*

*xlsx_path: excel文件所在的路径*

*xlsx_name:excel文件,例如a.xlsx*

'''

msg = MIMEMultipart()

#添加纯文本,text为需要输入的文本,字符串格式

text_msg = MIMEText(text)

msg.attach(text_msg)

def add_excel(xlsx_file,xlsx_name):#添加excel附件

# 将xlsx文件作为内容发送到对方的邮箱读取excel,rb形式读取,对于MIMEText()来说默认的编码形式是base64 对于二进制文件来说没有设置base64,会出现乱码

msg_xlsx = MIMEText(open(xlsx_file, 'rb').read(), 'base64', 'utf-8')

# 设置文件在附件当中的名字

msg_xlsx.add_header('Content-Disposition', 'attachment', filename=xlsx_name)

return msg_xlsx

msg_xlsx = add_excel(path + xlsx_name, xlsx_name)

msg.attach(msg_xlsx)

return msg

2、登陆邮箱

def login_email(smtpsever, username, pwd):

'''

*smtpsever: 邮箱服务器*

*username: 邮箱地址*

*pwd: 邮箱登陆密码*

'''

#连接邮箱服务器

sever = smtplib.SMTP(smtpsever)

#登陆邮箱

result = sever.login(username, pwd)

print('登陆结果:', result)

return sever

3、发送邮件

def send_email(title, sender, to_receiver, cc_receiver, sever, msg):

'''

Subject邮件主体,对应要发送的邮件名,对应值title为字符串

From发件人地址,对应值sender为发送人邮箱地址

To收件人邮箱地址,Cc抄送人邮箱地址

to_receiver-> list

cc_receiver-> list,可批量发送

sever: 第2步函数返回sever

msg: 第1步函数返回邮件主体

'''

msg['Subject'] = title

msg['From'] = sender

msg['To'] = ';'.join(to_receiver)

msg['Cc'] = ';'.join(cc_receiver)

receiver = ';'.join(to_receiver + cc_receiver)

sever.sendmail(sender, receiver.split(;), msg.as_string())

print('收件人', receiver)

参考

添加各类型附件: https://blog.csdn.net/handsomekang/article/details/9811355

代码解释:https://cloud.tencent.com/developer/article/1353552

主送、抄送、暗送:https://blog.csdn.net/nameofcsdn/article/details/76259998

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值