当前位置: 首页 > news >正文

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自动化办公的兴趣和热情。
 

相关文章:

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

目录 一、引言 二、案例背景 三、实战案例 (一)文件自动整理 (二)邮件自动发送 四、结语 一、引言 随着办公自动化的兴起,Python作为一门强大的编程语言,逐渐被应用于日常办公中。从文件整理到邮件…...

2024中国(重庆)无人机展览会8月在重庆举办

2024中国(重庆)无人机展览会8月在重庆举办 邀请函 主办单位: 中国航空学会 重庆市南岸区人民政府 招商执行单位: 重庆港华展览有限公司 报名:【交易会I 59交易会2351交易会9466】 展会背景: 为更好的培养航空航天产业和无人…...

自动驾驶技术与传感器数据处理

目录 自动驾驶总体架构 感知系统 决策系统 定位系统 ​计算平台​ 仿真平台​ 自动驾驶公开数据集 激光点云 点云表征方式 1) 原始点云 2) 三维点云体素化 3)深度图 4)鸟瞰图 点云检测障碍物的步骤 PCL点云库 车载毫米波雷达 车载相机 设备标定 自动驾驶…...

高效测评系统方案助力沃尔玛、亚马逊卖家提升产品销量

无论在哪个电商平台,测评确实是最有效的推广方式。测之前一定要选好产品,因为对于大部分卖家而言,不可能你店铺里所有的都是爆款,所以选择的是需要有潜力成为爆款的产品。测评是指通过搭建安全的环境模拟真实的买家购物行为&#…...

B/S模式的web通信(高并发服务器)

这里写目录标题 目标实现的目标 服务器代码(采用epoll实现服务器)整体框架main函数init_listen_fd函数(负责对lfd初始化的那一系列操作)epoll_run函数do_accept函数do_read函数内容补充:http中的getline函数 详解do_re…...

C语言每日一题—约瑟夫问题

13个人围成一圈,从第1个人开始顺序报号1、2、3,凡报到3的人退出圈子。找出最后留在圈子里的人原来的序号。要求用结构体编程实现。***输出提示:"\n出圈成员及顺序:" ***输出格式:"%3d" ***输出提示…...

语言:C#

一、VSCode生成exe 二、...

[力扣题解]45. 跳跃游戏 II

题目:45. 跳跃游戏 II 思路 贪心法; 只需记录2个变量,当前点能达到的最远距离,和上一步能到达的最远距离; (真有意思,代码随想录给出的是curDistance,nextDistance2个,…...

pywinauto操作windows应用(未完成)

pywinauto 脚本制作 一 、获取窗口句柄 首先获取句柄,其次扫描组件,然后对按钮和文本进行操作 安装依赖 pip install pywin32 -i https://pypi.doubanio.com/simple扫描全部的句柄 import win32gui# GetDesktopWindow 获得代表整个屏幕的一个窗口&a…...

(超详细讲解)实现将idea的java程序打包成exe (新版,可以在没有java的电脑下运行,即可以发给好朋友一起玩)

目录 实现打包到exe大概步骤 工具准备 1.将java程序文件打包成jar文件 2.准备好jre文件 3.使用exe4j软件打包好 4.最终打包 实现打包到exe大概步骤 1.打包需要满足的条件:将java文件转成jar文件的工具exe4j、 以及需要满足jdk1.8以上(因安装exe4…...

学习软考----数据库系统工程师29

数据操作 SELECT基本结构 简单查询 连接查询 子查询 聚集函数 分组查询 字符串操作 集合操作 外连接 INSERT INTO语句 DELETE语句 UPDATE语句...

STL中的优先级队列

目录 1.引言 2.简介 3.基本操作 4.实现原理 5.自定义优先级比较 6.相关题目 7.能特点 8.总结 1.引言 在C标准库中,优先级队列是一种非常有用的数据结构,它允许我们根据元素的优先级来对其进行排序和访问。这种数据结构在多种应用场景中都发挥着重…...

浅谈Acrel-2000ES储能能量管理系统的设计与应用-安科瑞 蒋静

0 前言 为进一步提升河南省分布式光伏发电发展水平,促进行业健康可持续发展,河南省发布关于促进分布式光伏发电健康可持续发展的通知。对于储能行业,可以用到安科瑞Acrel-2000ES储能能量管理系统。 储能柜EMS能量管理系统 1、产品名称 储…...

会员卡积分小程序系统源码商业运营版 行业一站式解决方案附带源代码以及搭建安装部署教程

系统概述 会员卡积分小程序系统源码商业运营版是一套完整的会员卡积分系统解决方案,包含前端小程序、后端管理系统以及数据库设计。该系统支持多种会员卡类型、积分规则设定、积分兑换、优惠券发放等功能,满足企业对于会员积分管理的各种需求。同时&…...

uniapp 百度地图 拖动获取经纬度级搜索连用

import loadBMap from /utils/loadBMap.js// 百度聚合具体代码 // 拖动 initMapc() {let that thisloadBMap(百度key).then(() > {map new BMap.Map(mapContainer)const centerPoint new BMap.Point(this.longitude, this.latitude)map.centerAndZoom(centerPoint, this.…...

Yarn的安装和使用详细教程(Mac/Window)

目录 Yarn是什么? Mac安装Yarn 使用Homebrew安装Yarn 使用npm安装Yarn Windows安装Yarn 使用npm安装Yarn Yarn使用 常用命令: 特殊命令: Yarn是什么? Yarn是一个流行的包管理工具,用于管理JavaScript项目的依…...

高考志愿系统-学生管理模块分析

1.获取学生信息: 接口:http://localhost:81/dev-api/college_entrance/student/list?pageNum1&pageSize10 请求方式get 默认传参pageNum和pageSize,表示当前页,每页展示数量 首先通过startPage()方法获取分页参数当前页&…...

【问题实操】银河高级服务器操作系统实例分享,开机之后反复重启

1.服务器环境以及配置 物理机/虚拟机/云/容器 物理机 外网/私有网络/无网络 私有网络 处理器: PHYTIUM FT2000PLUS 2200 MHz 内存: 128 GiB 整机类型/架构: HIKVISION DS-V BIOS版本: HK 601FBE02HK 网卡&#xff1…...

攻防世界-web-unseping

题目 知识点 PHP代码审计PHP序列化和反序列化PHP中魔术方法命令执行绕过方式 解读源码 <?php highlight_file(__FILE__);class ease{private $method;private $args;function __construct($method, $args) {$this->method $method;$this->args $args;}function …...

网络网络层之(4)IPv4协议

网络网络层之(1)IPv4协议 Author: Once Day Date: 2024年4月4日 一位热衷于Linux学习和开发的菜鸟&#xff0c;试图谱写一场冒险之旅&#xff0c;也许终点只是一场白日梦… 漫漫长路&#xff0c;有人对你微笑过嘛… 全系列文档可参考专栏&#xff1a;通信网络技术_Once-Day的…...

16-LINUX--线程安全

一。线程安全 线程安全即就是在多线程运行的时候&#xff0c;不论线程的调度顺序怎样&#xff0c;最终的结果都是 一样的、正确的。那么就说这些线程是安全的。 要保证线程安全需要做到&#xff1a; 1&#xff09; 对线程同步&#xff0c;保证同一时刻只有一个线程访问临界资…...

Flask SQLAlchemy 技术指南

文章目录 什么是 Flask SQLAlchemy&#xff1f;安装 Flask SQLAlchemy创建 Flask 应用和数据库模型添加和查询数据运行 Flask 应用总结**数据库迁移&#xff08;Database Migrations&#xff09;****复杂查询****关系模型****事务处理****性能优化****安全性****扩展功能** Fla…...

js通过时间对JSON中的数据进行排序

需求 现在需要通过每一个数据段的date字段对数组的整体数据进行排序&#xff01; 元数据如下&#xff1a; var data [{"filename": "123","date": "2024-05-10 19:53:57","stand": "GB-14","filter":…...

leetcode206-Reverse Linked List

题目 给你单链表的头节点 head &#xff0c;请你反转链表&#xff0c;并返回反转后的链表。 示例 1&#xff1a; 输入&#xff1a;head [1,2,3,4,5] 输出&#xff1a;[5,4,3,2,1] 分析 用一个指针记录当前位置&#xff0c;另外一个指针记录当前位置的前一个位置&#xff0c…...

云计算第十二课

安装虚拟机 第一步新建虚拟机 选择自定义安装 下一步 选择稍后安装操作系统 选择系统类型和版本 选择虚拟机文件路径&#xff08;建议每台虚拟机单独存放并且路径不要有中文&#xff09;点击下一步 选择bios下一步 选择虚拟机处理器内核数量 默认硬盘或者自行调大硬盘 选择虚…...

【elasticsearch】慢查询替代查询审计的尝试

【elasticsearch】慢查询替代查询审计的尝试 使用了es有两年了&#xff0c;突然发现一个&#xff0c;es没有查询审计日志&#xff0c;某个用户查询了某个索引的审计。 找了官方文档和社区的回复都是说使用slow log替代慢查询。 尝试一下。 参考链接1&#xff1a;https://discus…...

腐烂的橘子BFS

题目&#xff1a; 腐烂的橘子 在给定的 m x n 网格 grid 中&#xff0c;每个单元格可以有以下三个值之一&#xff1a; 值 0 代表空单元格&#xff1b; 值 1 代表新鲜橘子&#xff1b; 值 2 代表腐烂的橘子。 每分钟&#xff0c;腐烂的橘子 周围 4 个方向上相邻 的新鲜橘子…...

什么是分库分表

读写分离主要应对的是数据库读并发&#xff0c;没有解决数据库存储问题。试想一下&#xff1a;如果 MySQL 一张表的数据量过大怎么办? 答案当然是分库分表 什么是分库&#xff1f; 分库 就是将数据库中的数据分散到不同的数据库上&#xff0c;可以垂直分库&#xff0c;也可…...

pytest并发执行用例方案

背景 开始做新项目的UI自动化&#xff0c;需要考虑用例的并发执行&#xff0c;因为之前做的项目是通过插件pytest-parallel 0.1.1 pytest-multithreading-allure 1.0.8来实现的&#xff0c;所以这次也打算用此方法&#xff0c;然而在实际使用过程中发现一些问题。 问题一 通…...

VO,PO,DTO

DTO&#xff08;Data Transfer Object&#xff09;数据传输对象 前后端之间的传输时使用 比如前端登录请求的请求参数有username&#xff0c;password&#xff0c;但后端pojo类user有username&#xff0c;password&#xff0c;birthday&#xff0c;gender时&#xff0c;可以创…...