Python自动化办公实战案例:文件整理与邮件发送

简介: Python自动化办公实战案例:文件整理与邮件发送

一、引言

随着办公自动化的兴起,Python作为一门强大的编程语言,逐渐被应用于日常办公中。从文件整理到邮件发送,Python都能提供高效的解决方案。本文将通过一个实战案例,详细介绍如何使用Python实现文件自动整理与邮件自动发送,帮助新手朋友更好地理解和应用Python自动化办公。

二、案例背景

假设我们每天都需要处理大量的文件,这些文件包括各种格式(如Word、Excel、PDF等),并且需要按照不同的类别进行整理。同时,我们还需要定期向指定的客户发送这些文件。传统的做法需要手动进行文件分类、整理以及邮件发送,工作量大且容易出错。因此,我们可以使用Python编写自动化脚本,实现文件的自动整理与邮件的自动发送。

三、实战案例

(一)文件自动整理

需求分析

首先,我们需要明确文件整理的需求。假设我们的文件存放在一个名为input_folder的文件夹中,我们需要将这些文件按照不同的类别(如Word、Excel、PDF等)整理到不同的文件夹中。

解决方案

我们可以使用Python的os和shutil模块来实现文件的自动整理。具体步骤如下:

(1)遍历input_folder文件夹中的所有文件;

(2)根据文件扩展名判断文件类型,并将文件移动到对应的文件夹中;

(3)如果对应的文件夹不存在,则创建该文件夹。

代码实现

import os  
import shutil  
  
def sort_files(input_folder, output_base_folder):  
    # 遍历input_folder文件夹中的所有文件  
    for filename in os.listdir(input_folder):  
        file_path = os.path.join(input_folder, filename)  
          
        # 判断文件是否为普通文件  
        if os.path.isfile(file_path):  
            # 获取文件扩展名  
            extension = os.path.splitext(filename)[1][1:].lower()  
              
            # 定义文件目标文件夹  
            output_folder = os.path.join(output_base_folder, extension)  
              
            # 如果目标文件夹不存在,则创建  
            if not os.path.exists(output_folder):  
                os.makedirs(output_folder)  
              
            # 将文件移动到目标文件夹  
            shutil.move(file_path, os.path.join(output_folder, filename))  
  
# 使用示例  
input_folder = 'path/to/input_folder'  # 替换为实际的输入文件夹路径  
output_base_folder = 'path/to/output_base_folder'  # 替换为实际的输出文件夹路径  
sort_files(input_folder, output_base_folder)

(二)邮件自动发送

需求分析

在文件整理完成后,我们需要向指定的客户发送这些文件。假设我们已经有了一个包含客户邮箱和文件路径的CSV文件,我们需要编写一个Python脚本,自动读取CSV文件,并向对应的邮箱发送邮件,附带上对应的文件。

解决方案

我们可以使用Python的smtplib和email模块来实现邮件的自动发送。具体步骤如下:

(1)读取CSV文件,获取客户邮箱和文件路径;

(2)使用smtplib模块连接到邮件服务器;

(3)使用email模块构建邮件内容,并添加附件;

(4)发送邮件。代码实现

 

import csv  
import smtplib  
from email.mime.multipart import MIMEMultipart  
from email.mime.text import MIMEText  
from email.mime.base import MIMEBase  
from email import encoders  
  
def send_email(sender, password, recipients, subject, body, attachment_path):  
    # 创建邮件对象  
    msg = MIMEMultipart()  
      
    # 设置邮件信息  
    msg['From'] = sender  
    msg['To'] = ', '.join(recipients)  
    msg['Subject'] = subject  
      
    # 设置邮件正文  
    msg.attach(MIMEText(body, 'plain'))  
      
    # 添加附件  
    with open(attachment_path, 'rb') as attachment:  
        part = MIMEBase('application', 'octet-stream')  
        part.set_payload(attachment.read())  
        encoders.encode_base64(part)  
        part.add_header('Content-Disposition', "attachment; filename= " + os.path.basename(attachment_path))  
        msg.attach(part)  
      
    # 连接邮件服务器并发送邮件  
    with smtplib.SMTP('smtp.example.com', 5587) as server:
          server.starttls()
          server.login(sender, password)
          server.sendmail(sender, recipients, msg.as_string())
def send_emails_from_csv(csv_file_path, sender, password):
       with open(csv_file_path, 'r', encoding='utf-8') as csvfile:
            reader = csv.DictReader(csvfile)
       for row in reader:
            recipient = row['Email']
            attachment_path = row['FilePath']
            subject = "File Attachment"
            body = "Please find the attached file."
            send_email(sender, password, [recipient], subject, body, attachment_path)
 
#使用示例
csv_file_path = 'path/to/emails.csv' # 替换为实际的CSV文件路径
sender = 'your-email@example.com' # 替换为发件人邮箱
password = 'your-email-password' # 替换为发件人邮箱密码
send_emails_from_csv(csv_file_path, sender, password)

四、结语  

Python自动化办公为我们带来了很多便利,通过编写自动化脚本,我们可以轻松实现文件的自动整理、邮件的自动发送等任务。希望本文的实战案例能对新手朋友有所帮助,激发大家对Python自动化办公的兴趣和热情。

 


目录
相关文章
|
1月前
|
Python
使用Python实现multipart/form-data文件接收的http服务器
至此,使用Python实现一个可以接收 'multipart/form-data' 文件的HTTP服务器的步骤就讲解完毕了。希望通过我的讲解,你可以更好地理解其中的逻辑,另外,你也可以尝试在实际项目中运用这方面的知识。
144 69
|
1月前
|
人工智能 安全 虚拟化
Cua:Mac用户狂喜!这个开源框架让AI直接接管你的电脑,快速实现AI自动化办公
Cua是一个结合高性能虚拟化与AI代理能力的开源框架,能在Apple Silicon上以接近原生性能运行虚拟机,并让AI直接操作系统应用。
186 17
Cua:Mac用户狂喜!这个开源框架让AI直接接管你的电脑,快速实现AI自动化办公
|
1月前
|
人工智能 运维 API
无需配置开箱即用!MoLing:基于MCP开发的自动化办公服务,一键搞定文件与网页操作
MoLing是一款基于Go语言开发的跨平台办公自动化工具,通过操作系统API和浏览器自动化框架实现文件操作、命令执行及网页控制,无需额外依赖即可运行。
117 1
无需配置开箱即用!MoLing:基于MCP开发的自动化办公服务,一键搞定文件与网页操作
|
20天前
|
Shell 开发者 Docker
Python文件打包:一站式指南
本文深入探讨Python文件打包的各种方法,从基础的zip和tar工具到高级的setuptools、PyInstaller、cx_Freeze等,涵盖Docker镜像、虚拟环境及自包含可执行文件的打包方式。通过示例代码与详细解析,帮助开发者根据项目需求选择合适的打包方案,提升代码分发与部署效率。内容全面,适合各水平读者学习参考。
|
2月前
|
存储 算法 文件存储
探秘文件共享服务之哈希表助力 Python 算法实现
在数字化时代,文件共享服务不可或缺。哈希表(散列表)通过键值对存储数据,利用哈希函数将键映射到特定位置,极大提升文件上传、下载和搜索效率。例如,在大型文件共享平台中,文件名等信息作为键,物理地址作为值存入哈希表,用户检索时快速定位文件,减少遍历时间。此外,哈希表还用于文件一致性校验,确保传输文件未被篡改。以Python代码示例展示基于哈希表的文件索引实现,模拟文件共享服务的文件索引构建与检索功能。哈希表及其分布式变体如一致性哈希算法,保障文件均匀分布和负载均衡,持续优化文件共享服务性能。
|
3月前
|
SQL JSON 数据可视化
基于 DIFY 的自动化数据分析实战
本文介绍如何使用DIFY搭建数据分析自动化流程,实现从输入需求到查询数据库、LLM分析再到可视化输出的全流程。基于经典的employees数据集和DIFY云端环境,通过LLM-SQL解析、SQL执行、LLM数据分析及ECharts可视化等模块,高效完成数据分析任务。此方案适用于人力资源分析、薪酬管理等数据密集型业务,显著提升效率并降低成本。
7203 13
|
2月前
|
机器学习/深度学习 设计模式 测试技术
Python 高级编程与实战:构建自动化测试框架
本文深入探讨了Python中的自动化测试框架,包括unittest、pytest和nose2,并通过实战项目帮助读者掌握这些技术。文中详细介绍了各框架的基本用法和示例代码,助力开发者快速验证代码正确性,减少手动测试工作量。学习资源推荐包括Python官方文档及Real Python等网站。
|
12月前
|
API Python
Python邮箱API发送邮件的方法和步骤
使用Python发送邮件涉及导入smtplib和email模块,设置发件人、收件人、主题和内容,然后连接SMTP服务器(如示例中的smtp.example.com)并使用SMTP方法发送。完整代码示例包括异常处理,确保邮件发送成功或提供错误信息。通过这种方式,可以实现Python的自动化邮件发送功能。
|
数据安全/隐私保护 Python
Python 技术篇-连接qq邮箱服务器,调用qq邮箱发送邮件实战演示,qq邮箱授权码开通方法
Python 技术篇-连接qq邮箱服务器,调用qq邮箱发送邮件实战演示,qq邮箱授权码开通方法
699 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服务器发送指令,执行相关操作(如:登陆、发送邮件)。
1049 0