Python办公自动化实战:手把手教你打造智能邮件发送工具

简介: 本文介绍如何使用Python的smtplib和email库构建智能邮件系统,支持图文混排、多附件及多收件人邮件自动发送。通过实战案例与代码详解,帮助读者快速实现办公场景中的邮件自动化需求。

前言
在数字化办公场景中,邮件自动化是提升工作效率的关键技能。本文将通过实际案例,演示如何使用Python的smtplib和email库构建一个支持图文混排、多附件、多收件人的智能邮件系统。无需复杂配置,只需跟随步骤操作,即可实现邮件自动化发送。
zdaye (2).png

一、基础配置:搭建邮件发送框架
1.1 邮箱服务准备
以163邮箱为例,首先需要开启SMTP服务:

登录邮箱后进入设置界面
选择"POP3/SMTP/IMAP"选项
开启SMTP服务并获取授权码(注意:授权码将替代登录密码使用)
1.2 核心库导入
import smtplib
from email.mime.multipart import MIMEMultipart
from email.mime.text import MIMEText
from email.mime.image import MIMEImage
from email.header import Header

1.3 基础发送函数
def send_email(config):
msg = MIMEMultipart()
msg['From'] = config['sender']
msg['To'] = ', '.join(config['receivers'])
msg['Subject'] = Header(config['subject'], 'utf-8')

# 添加正文
msg.attach(MIMEText(config['body'], 'html', 'utf-8'))

try:
    with smtplib.SMTP_SSL(config['smtp_server'], config['port']) as server:
        server.login(config['sender'], config['password'])
        server.sendmail(config['sender'], config['receivers'], msg.as_string())
    print("邮件发送成功")
except Exception as e:
    print(f"发送失败: {str(e)}")

二、进阶功能实现
2.1 多附件处理
def add_attachments(msg, file_paths):
for file_path in file_paths:
with open(file_path, 'rb') as f:
attachment = MIMEText(f.read(), 'base64', 'utf-8')
attachment['Content-Type'] = 'application/octet-stream'
attachment['Content-Disposition'] = f'attachment; filename="{file_path.split("/")[-1]}"'
msg.attach(attachment)

2.2 图文混排实现
def add_images(msg, image_paths):
for img_path in image_paths:
with open(img_path, 'rb') as f:
img = MIMEImage(f.read())
img.add_header('Content-ID', f'<{img_path.split("/")[-1]}>')
msg.attach(img)

2.3 多收件人优化
def validate_receivers(receivers):
valid_emails = []
for email in receivers:
if '@' in email and '.' in email.split('@')[1]:
valid_emails.append(email)
return valid_emails

三、完整实战案例
3.1 场景描述
某公司需要向全体员工发送季度工作报告,要求包含:

PDF格式的正式报告
业绩趋势图(PNG格式)
Excel格式的详细数据
邮件正文需要包含图表引用
3.2 完整代码实现
def main():

# 配置参数
config = {
    'sender': 'your_email@163.com',
    'password': '授权码',
    'smtp_server': 'smtp.163.com',
    'port': 465,
    'receivers': ['test1@example.com', 'test2@example.com'],
    'subject': '2025年第二季度工作报告',
    'body': '''
    <h1>季度工作报告</h1>
    <p>附件包含详细数据,正文图表如下:</p>
    <img src="cid:业绩趋势图.png">
    '''
}

# 创建邮件对象
msg = MIMEMultipart()
msg['From'] = config['sender']
msg['To'] = ', '.join(config['receivers'])
msg['Subject'] = Header(config['subject'], 'utf-8')

# 添加正文
msg.attach(MIMEText(config['body'], 'html', 'utf-8'))

# 添加附件
add_attachments(msg, [
    './reports/季度数据.xlsx',
    './reports/正式报告.pdf'
])

# 添加图片
add_images(msg, [
    './charts/业绩趋势图.png'
])

# 发送邮件
send_email(config, msg)

if name == 'main':
main()

四、扩展功能建议
4.1 定时发送
结合schedule库实现定时任务:

import schedule
import time

schedule.every().day.at("09:30").do(main)

while True:
schedule.run_pending()
time.sleep(60)

4.2 批量发送
从CSV读取收件人信息:

import pandas as pd

def batch_send(csv_path):
df = pd.read_csv(csv_path)
for index, row in df.iterrows():
config['receivers'] = [row['email']]
config['body'] = f"尊敬的{row['name']},这是您的专属报告"
main()

4.3 异常处理
添加重试机制和日志记录:

import logging
from retrying import retry

logging.basicConfig(filename='email.log', level=logging.INFO)

@retry(stop_max_attempt_number=3)
def send_email_safe(config, msg):
try:

    # 原有发送逻辑
    logging.info(f"成功发送至{config['receivers']}")
except Exception as e:
    logging.error(f"发送失败: {str(e)}")
    raise

五、注意事项
授权码安全:建议定期更换邮箱授权码
文件路径:使用绝对路径或相对路径时注意工作目录
邮件大小:单个邮件附件建议不超过20MB
测试验证:发送测试邮件时建议使用自己的邮箱作为收件人
服务器限制:部分邮箱服务器有每日发送量限制
通过本文介绍的方案,可以实现从简单邮件到复杂邮件的自动化发送。实际使用中可根据需求添加模板引擎、数据库集成等功能,构建更完善的邮件自动化系统。

目录
相关文章
|
4月前
|
SQL 关系型数据库 数据库
Python SQLAlchemy模块:从入门到实战的数据库操作指南
免费提供Python+PyCharm编程环境,结合SQLAlchemy ORM框架详解数据库开发。涵盖连接配置、模型定义、CRUD操作、事务控制及Alembic迁移工具,以电商订单系统为例,深入讲解高并发场景下的性能优化与最佳实践,助你高效构建数据驱动应用。
579 7
|
4月前
|
数据采集 Web App开发 数据安全/隐私保护
实战:Python爬虫如何模拟登录与维持会话状态
实战:Python爬虫如何模拟登录与维持会话状态
|
4月前
|
Java 调度 数据库
Python threading模块:多线程编程的实战指南
本文深入讲解Python多线程编程,涵盖threading模块的核心用法:线程创建、生命周期、同步机制(锁、信号量、条件变量)、线程通信(队列)、守护线程与线程池应用。结合实战案例,如多线程下载器,帮助开发者提升程序并发性能,适用于I/O密集型任务处理。
454 0
|
4月前
|
存储 人工智能 自然语言处理
拔俗AI自动化评价分析系统:让数据说话,让决策更智能
在用户体验为核心的时代,传统评价分析面临效率低、洞察浅等痛点。本文基于阿里云AI与大数据技术,构建“数据-算法-应用”三层智能分析体系,实现多源数据实时接入、情感与主题精准识别、跨模态融合分析及实时预警,助力企业提升运营效率、加速产品迭代、优化服务质量,并已在头部电商平台成功落地,显著提升用户满意度与商业转化。
486 0
|
4月前
|
机器学习/深度学习 监控 数据挖掘
Python 高效清理 Excel 空白行列:从原理到实战
本文介绍如何使用Python的openpyxl库自动清理Excel中的空白行列。通过代码实现高效识别并删除无数据的行与列,解决文件臃肿、读取错误等问题,提升数据处理效率与准确性,适用于各类批量Excel清理任务。
522 0
|
API Python
Python邮箱API发送邮件的方法和步骤
使用Python发送邮件涉及导入smtplib和email模块,设置发件人、收件人、主题和内容,然后连接SMTP服务器(如示例中的smtp.example.com)并使用SMTP方法发送。完整代码示例包括异常处理,确保邮件发送成功或提供错误信息。通过这种方式,可以实现Python的自动化邮件发送功能。
|
数据安全/隐私保护 Python
Python 技术篇-连接qq邮箱服务器,调用qq邮箱发送邮件实战演示,qq邮箱授权码开通方法
Python 技术篇-连接qq邮箱服务器,调用qq邮箱发送邮件实战演示,qq邮箱授权码开通方法
1200 0
Python 技术篇-连接qq邮箱服务器,调用qq邮箱发送邮件实战演示,qq邮箱授权码开通方法
|
Web App开发 Python
python发送各类邮件的主要方法
python中email模块使得处理邮件变得比较简单,今天着重学习了一下发送邮件的具体做法,这里写写自己的的心得,也请高手给些指点。     一、相关模块介绍     发送邮件主要用到了smtplib和email两个模块,这里首先就两个模块进行一下简单的介绍:    1、smtplib模块       smtplib.SMTP([host[, port[, local_hostname[, timeout]]]])    SMTP类构造函数,表示与SMTP服务器之间的连接,通过这个连接可以向smtp服务器发送指令,执行相关操作(如:登陆、发送邮件)。
1118 0
|
Python 安全 数据安全/隐私保护
python发送各类邮件的主要方法
python中email模块使得处理邮件变得比较简单,今天着重学习了一下发送邮件的具体做法,这里写写自己的的心得,也请高手给些指点。     一、相关模块介绍     发送邮件主要用到了smtplib和email两个模块,这里首先就两个模块进行一下简单的介绍:    1、smtplib模块       smtplib.SMTP([host[, port[, local_hostname[, timeout]]]])    SMTP类构造函数,表示与SMTP服务器之间的连接,通过这个连接可以向smtp服务器发送指令,执行相关操作(如:登陆、发送邮件)。
1320 0

热门文章

最新文章

推荐镜像

更多