用Python实现自动化批量邮件发送
off999 2024-12-13 15:35 12 浏览 0 评论
用Python实现自动化批量邮件发送
在日常办公中,批量发送邮件是一个非常常见但繁琐的任务,比如通知客户、发送会议提醒、或者传递重要文件。用Python,我们可以轻松实现批量邮件的自动化发送,节省时间的同时还能减少手工操作带来的错误。
今天,我就带大家一步步实现一个简单而强大的邮件发送脚本,从读取联系人名单到生成个性化邮件,再到发送邮件,全部搞定!
准备工作:了解Python邮件发送的基础知识
在Python中,发送邮件主要用到两个模块:
- smtplib:负责连接邮件服务器并发送邮件。
- email:用于构建邮件内容,包括主题、正文、附件等。
工作流程可以理解为:
- 连接到你的邮箱服务器(比如Gmail或QQ邮箱)。
- 编写邮件内容。
- 将邮件批量发送给联系人。
小贴士:在开始之前,确保你有一个支持SMTP功能的邮箱(比如Gmail、QQ、Outlook等),并开启SMTP服务。
第一步:搭建邮件发送的基本框架
我们先写一个最基础的代码,完成单封邮件的发送。这是整个流程的核心。
示例代码:
import smtplib
from email.mime.text import MIMEText
from email.mime.multipart import MIMEMultipart
# 邮箱配置
smtp_server = "smtp.gmail.com" # SMTP服务器地址
smtp_port = 587 # SMTP端口号(通常为587)
sender_email = "你的邮箱@gmail.com" # 发件人邮箱
sender_password = "你的邮箱密码" # 邮箱授权码或密码
# 构建邮件内容
message = MIMEMultipart()
message["From"] = sender_email
message["To"] = "收件人邮箱@example.com"
message["Subject"] = "Python自动化邮件测试"
# 邮件正文
body = "你好,这是一封通过Python发送的自动化邮件!"
message.attach(MIMEText(body, "plain"))
# 连接SMTP服务器并发送邮件
try:
with smtplib.SMTP(smtp_server, smtp_port) as server:
server.starttls() # 开启加密传输
server.login(sender_email, sender_password) # 登录邮箱
server.sendmail(sender_email, message["To"], message.as_string()) # 发送邮件
print("邮件发送成功!")
except Exception as e:
print(f"邮件发送失败:{e}")
代码解读:
- smtplib.SMTP:连接到SMTP服务器。
- server.starttls():启用TLS加密,确保传输安全。
- server.login():登录邮箱账户。
- server.sendmail():发送邮件。
注意事项:某些邮箱(如QQ邮箱、Gmail)需要设置授权码而不是直接使用密码。这可以在邮箱的“设置”中找到。
第二步:实现批量发送
单封邮件搞定后,我们进一步实现批量发送邮件。比如,从Excel文件中读取收件人列表,并为每个收件人生成个性化的邮件内容。
示例代码:
import pandas as pd
# 假设有一个Excel文件"contacts.xlsx",包含两列:Name 和 Email
contacts_file = "contacts.xlsx"
# 读取联系人信息
contacts = pd.read_excel(contacts_file)
print(contacts.head()) # 查看前几行数据
# 批量发送邮件
for index, row in contacts.iterrows():
recipient_name = row["Name"]
recipient_email = row["Email"]
# 构建个性化邮件内容
body = f"你好 {recipient_name},\n\n这是为你量身定制的邮件!希望你喜欢这次Python学习之旅!"
message["To"] = recipient_email
message.attach(MIMEText(body, "plain"))
# 发送邮件(与前面代码类似)
try:
with smtplib.SMTP(smtp_server, smtp_port) as server:
server.starttls()
server.login(sender_email, sender_password)
server.sendmail(sender_email, recipient_email, message.as_string())
print(f"邮件已发送给 {recipient_name} ({recipient_email})!")
except Exception as e:
print(f"发送给 {recipient_name} 的邮件失败:{e}")
实际场景:
- 企业通知:从Excel读取客户列表,发送节日问候或促销邮件。
- 会议邀请:给公司员工发送会议提醒。
小贴士:使用Excel管理联系人非常方便。如果你的联系人信息是从数据库导出,也可以用类似方法处理。
第三步:添加附件和多媒体内容
一封邮件如果有附件或图片,会显得更加专业。接下来,我们为邮件添加一个PDF附件。
示例代码:
from email.mime.base import MIMEBase
from email import encoders
# 添加附件
filename = "附件.pdf" # 替换为你的文件名
with open(filename, "rb") as attachment:
part = MIMEBase("application", "octet-stream")
part.set_payload(attachment.read())
# 对附件进行编码
encoders.encode_base64(part)
part.add_header(
"Content-Disposition",
f"attachment; filename={filename}",
)
message.attach(part)
print("附件已添加!")
应用场景:
- 给客户发送报价单或合同。
- 分享工作报告或学习资料。
第四步:优化代码结构
为了让代码更简洁,我们可以将常用功能封装成函数,比如登录、发送单封邮件等。
示例代码:
def send_email(to_email, subject, body, attachment=None):
"""发送一封带附件的邮件"""
message = MIMEMultipart()
message["From"] = sender_email
message["To"] = to_email
message["Subject"] = subject
message.attach(MIMEText(body, "plain"))
# 添加附件(如果有)
if attachment:
with open(attachment, "rb") as file:
part = MIMEBase("application", "octet-stream")
part.set_payload(file.read())
encoders.encode_base64(part)
part.add_header("Content-Disposition", f"attachment; filename={attachment}")
message.attach(part)
# 发送邮件
with smtplib.SMTP(smtp_server, smtp_port) as server:
server.starttls()
server.login(sender_email, sender_password)
server.sendmail(sender_email, to_email, message.as_string())
调用这个函数,我们的代码会更加清晰易读。
小练习:
- 尝试为不同的人添加不同的附件,比如给客户发送不同的报价单。
- 优化邮件正文,加入HTML内容,让邮件看起来更漂亮。
- 如果遇到错误(如邮件被退回),学会查找原因并解决。
相关推荐
- 独家 | 5 个Python高级特性让你在不知不觉中成为Python高手
-
你已经使用Python编程了一段时间,编写脚本并解决各种问题。是你的水平出色吗?你可能只是在不知不觉中利用了Python的高级特性。从闭包(closure)到上下文管理器(contextmana...
- Python装饰器
-
Python装饰器是一种用于修改函数或类的行为的特殊语法。它们允许在不修改原始代码的情况下,通过将函数或类作为参数传递给另一个函数来添加额外的功能。装饰器本质上是一个函数,它接受一个函数作为参数,并返...
- 中高阶Python常规用法--上下文管理器
-
Python以简单性和通用性著称,是一种深受全球开发人员喜爱的编程语言。它提供了大量的特性和功能,使编码成为一种愉快的体验。在这些功能中,一个经常被新手忽视的强大工具是上下文管理器。上下文管理器是高...
- Python小案例67- 装饰器
-
Python装饰器是一种用于修改函数或类的行为的特殊语法。它们允许在不修改原始代码的情况下,通过将函数或类作为参数传递给另一个函数来添加额外的功能。装饰器本质上是一个函数,它接受一个函数作为参数,并返...
- python常用的语法糖
-
概念Python的语法糖(SyntacticSugar)是指那些让代码更简洁、更易读的语法特性,它们本质上并不会增加新功能,但能让开发者更高效地编写代码。推导式写法推导式是Python最经典的...
- python - 常用的装饰器 decorator 有哪些?
-
python编程中使用装饰器(decorator)工具,可以使代码更简洁清晰,提高代码的重用性,还可以为代码维护提供方便。对于python初学者来说,根据装饰器(decorator)的字面意思并不...
- python数据缓存怎么搞 ?推荐一个三方包供你参考,非常简单好用。
-
1.数据缓存说明数据缓存可以说也是项目开发中比不可少的一个工具,像我们测试的系统中,你都会见到像Redis一样的数据缓存库。使用缓存数据库的好处不言而喻,那就是效率高,简单数据直接放在缓存中...
- 用于时间序列数据的Graphite监视工具
-
结合第三方工具,Graphite为IT性能监控提供了许多好处。本文介绍其核心组件,包括Carbon、Whisper以及安装的基本准则。Graphite监视工具可实时或按需,大规模地绘制来自多个来源的时...
- Python3+pygame实现的坦克大战
-
一、显示效果二、代码1.说明几乎所有pygame游戏,基本都遵循一定的开发流程,大体如下:初始化pygame创建窗口while循环检测以及处理事件(鼠标点击、按键等)更新UI界面2.代码创建一个m...
- Python之鸭子类型:一次搞懂with与上下文装饰器
-
引言在鸭子类型的理念的基础之上,从关注类型,转变到关注特性和行为。结合Python中的魔法函数的体系,我们可以将自定义的类型,像内置类型一样被使用。今天这篇文章中,接着该话题,继续聊一下with语法块...
- Python必会的50个代码操作
-
学习Python时,掌握一些常用的程序操作非常重要。以下是50个Python必会的程序操作,主要包括基础语法、数据结构、函数和文件操作等。1.HelloWorldprint("Hello,...
- 一文掌握Python 中的同步和异步
-
同步代码(Sync)同步就像在一个流水线上工作,每个任务都等待前一个任务完成。示例:机器A切割钢板→完成后,机器B钻孔→完成后,机器C上色。在Python中,同步代码看起来像这样:im...
- python 标注模块timeit: 测试函数的运行时间
-
在Python中,可以使用内置的timeit模块来测试函数的运行时间。timeit模块提供了一个简单的接口来测量小段代码的执行时间。以下是使用timeit测试函数运行时间的一般步骤:导入...
- Python带你找回童年的万花尺
-
还记得小时候的万花尺吧?这么画:一点也不费脑筋,就可以出来这么多丰富多彩的复杂几何图形。具体而言,可以用万花尺玩具(如图2-1所示)来绘制数学曲线。这种玩具由两个不同尺寸的塑料齿轮组成,一大一小。小的...
- Python 时间模块深度解析:从基础到高级的全面指南
-
直接上干货一、时间模块核心类介绍序号类名说明1datetime.datetime表示一个具体的日期和时间,结合了日期和时间的信息。2datetime.date表示一个具体的日期。3datetime.t...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- python计时 (54)
- python安装路径 (54)
- python类型转换 (75)
- python进度条 (54)
- python的for循环 (56)
- python串口编程 (60)
- python写入txt (51)
- python读取文件夹下所有文件 (59)
- java调用python脚本 (56)
- python操作mysql数据库 (66)
- python字典增加键值对 (53)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python qt (52)
- python人脸识别 (54)
- python斐波那契数列 (51)
- python多态 (60)
- python命令行参数 (53)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- centos7安装python (53)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)