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

Python自动化办公

第五篇:Python自动化办公:10行代码搞定重复性工作

适合读者:职场人士、数据分析师 | 阅读时长:12分钟


引言

每天重复处理Excel、PDF或邮件?Python可以帮你自动化这些枯燥任务,节省90%的时间。本文通过实际案例,展示如何用10行以内的代码提升办公效率。


1. 批量处理Excel文件

场景:合并多个Excel表格中的销售数据。
传统方法:手动复制粘贴 → 容易出错 + 耗时。
Python方案

import pandas as pd
import glob# 读取所有Excel文件并合并
files = glob.glob("sales_*.xlsx")  # 匹配所有以sales_开头的文件
df = pd.concat([pd.read_excel(f) for f in files])
df.to_excel("combined_sales.xlsx", index=False)  # 输出合并后的文件

效果:3秒完成原本需要1小时的工作。


2. 自动发送邮件(带附件)

场景:每周定时发送报告给团队。
传统方法:手动编辑邮件 + 添加附件 → 枯燥且易忘。
Python方案

import smtplib
from email.mime.multipart import MIMEMultipart
from email.mime.text import MIMETextmsg = MIMEMultipart()
msg["From"] = "your_email@example.com"
msg["To"] = "team@example.com"
msg["Subject"] = "本周销售报告"
msg.attach(MIMEText("请查收附件中的最新数据。", "plain"))# 添加附件
with open("report.pdf", "rb") as f:attachment = MIMEText(f.read(), "base64", "utf-8")attachment["Content-Disposition"] = 'attachment; filename="report.pdf"'msg.attach(attachment)# 发送邮件(需配置SMTP服务器)
server = smtplib.SMTP("smtp.example.com", 587)
server.login("your_email@example.com", "password")
server.send_message(msg)
server.quit()

安全提示:建议使用keyring库存储密码,而非硬编码。


3. PDF批量转Word

场景:客户提供PDF合同,需转为Word编辑。
传统方法:使用付费软件逐个转换 → 费钱费时。
Python方案

from pdf2docx import Converterpdf_files = ["contract1.pdf", "contract2.pdf"]
for pdf in pdf_files:docx_file = pdf.replace(".pdf", ".docx")cv = Converter(pdf)cv.convert(docx_file, start=0, end=None)cv.close()

依赖库pip install pdf2docx
注意:复杂排版可能需微调。


4. 监控文件夹 + 自动备份

场景:实时备份重要文件到云端。
传统方法:手动拖拽到网盘 → 容易遗漏。
Python方案

import shutil
import time
from watchdog.observers import Observer
from watchdog.events import FileSystemEventHandlerclass BackupHandler(FileSystemEventHandler):def on_modified(self, event):if not event.is_directory:  # 只处理文件shutil.copy2(event.src_path, "/cloud_backup/")observer = Observer()
observer.schedule(BackupHandler(), path="/important_files/")
observer.start()try:while True:time.sleep(1)
except KeyboardInterrupt:observer.stop()
observer.join()

扩展:可集成Google Drive/Dropbox API实现真·云端备份。


5. 微信消息自动化(防撤回存档)

场景:保存重要群聊中的撤回消息。
技术栈itchat + 正则表达式
代码片段

import itchat
import re@itchat.msg_register(itchat.content.TEXT)
def save_recalled(msg):if "撤回了一条消息" in msg["Text"]:recalled = re.search(r'"(.+?)"', msg["Text"]).group(1)with open("recalled.txt", "a") as f:f.write(f"{msg['FromUserName']} 撤回:{recalled}\n")itchat.auto_login(hotReload=True)
itchat.run()

注意:需遵守平台使用规范,避免滥用。


结语

Python自动化不是程序员的专利。掌握这些脚本,你将成为办公室的效率明星。
下一步

  1. 尝试将脚本设置为定时任务(如用cron或Windows任务计划程序)
  2. 学习错误处理(try/except)让脚本更健壮

讨论:你最想自动化哪个办公场景?欢迎留言!


如需其他方向的自动化案例(如网页爬虫、图像处理等),可随时提出!

相关文章:

  • OFDM 信道表示(1)
  • 如何编制实施项目管理章程
  • shardingsphere-jdbc集成Seata分布式事务
  • 大模型提示词prompt
  • 解释`Function.__proto__ === Function.prototype`的结果及原因。
  • c#从ftp服务器下载文件读取csv
  • 在Vue项目中查询所有版本号为 1.1.9 的依赖包名 的具体方法,支持 npm/yarn/pnpm 等主流工具
  • 小目标、狭长目标检测的一些优化方法
  • RK3588 Buildroot 串口测试工具
  • es6面试常见问题╮(╯▽╰)╭
  • 【C++】Stack和Queue的底层封装和实现
  • 分享一下这几天在公司学到的东西
  • python学习 -- 综合案例1:设计一款基于python的飞机大战小游戏
  • 阿里云 AI 搜索开放平台新功能发布:大模型联网能力上线
  • java面试篇 4.9
  • 案例驱动的 IT 团队管理:创新与突破之路:第五章 创新管理:从机制设计到文化养成-5.1 创新激励体系-5.1.3失败案例的价值转化机制
  • Linux笔记---动静态库(原理篇)
  • java实现二叉树的前序、中序、后序遍历(递归和非递归方式)以及层级遍历
  • Windows10系统RabbitMQ无法访问Web端界面
  • MongoDB 分账号限制数据访问
  • 做免费网站教程/福建seo排名培训
  • 随州网站建设哪家专业/百度一下你就知道了百度一下
  • 设计师常备设计网站大全/在哪里找软件开发公司
  • 淮南矿业集团廉政建设网站/把百度网址大全设为首页
  • 做头像的网站空白/百度云登录入口
  • jsp动态网站开发教材/百度指数怎么查询