Python自动化办公

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

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


引言

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


1. 批量处理Excel文件

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

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方案

python 复制代码
import smtplib
from email.mime.multipart import MIMEMultipart
from email.mime.text import MIMEText

msg = 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方案

python 复制代码
from pdf2docx import Converter

pdf_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方案

python 复制代码
import shutil
import time
from watchdog.observers import Observer
from watchdog.events import FileSystemEventHandler

class 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 + 正则表达式
代码片段

python 复制代码
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)让脚本更健壮

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


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

相关推荐
你怎么知道我是队长3 分钟前
C语言---输入和输出
c语言·开发语言
mmz12077 分钟前
二分查找(c++)
开发语言·c++·算法
你怎么知道我是队长13 分钟前
C语言---文件读写
java·c语言·开发语言
陌路2014 分钟前
C++30 STL容器 -deque双端队列
开发语言·c++
踏浪无痕28 分钟前
架构师如何学习 AI:三个月掌握核心能力的务实路径
人工智能·后端·程序员
xb113233 分钟前
C#委托详解
开发语言·c#
brent42333 分钟前
DAY50复习日
开发语言·python
闲看云起36 分钟前
大模型应用开发框架全景图
人工智能·语言模型·ai编程
CoovallyAIHub40 分钟前
工业视觉检测:多模态大模型的诱惑
深度学习·算法·计算机视觉
木头程序员42 分钟前
前端(包含HTML/JavaScript/DOM/BOM/jQuery)基础-暴力复习篇
开发语言·前端·javascript·ecmascript·es6·jquery·html5