10个Python自动化办公的脚本分享

 更新时间:2025年02月08日 10:16:37   作者:victor66  
在日常办公中,我们常常会被繁琐、重复的任务占据大量时间,本文为大家分享了10个实用的 Python 自动化办公案例及源码,希望对大家有所帮助

在日常办公中,我们常常会被繁琐、重复的任务占据大量时间。Python 作为一门强大的编程语言,拥有丰富的库和工具,能够轻松实现办公自动化,大大提高工作效率。今天,就来给大家分享 10 个实用的 Python 自动化办公案例及源码。

1. 批量处理 Excel 文件

在处理数据时,经常需要对多个 Excel 文件进行相同操作。利用pandas库可以轻松实现。

import pandas as pd
import os
# 文件夹路径
folder\_path = 'your\_folder\_path'
for filename in os.listdir(folder\_path):
    if filename.endswith('.xlsx'):
        file\_path = os.path.join(folder\_path, filename)
        df = pd.read\_excel(file\_path)
        \# 这里可以对df进行各种操作,比如新增一列
        df\['new\_column'] = df\['原有列'] \* 2
        df.to\_excel(file\_path, index=False)

2. 自动发送邮件

使用smtplibemail库,自动发送邮件,适用于定期汇报等场景。

import smtplib
from email.mime.text import MIMEText
from email.header import Header
# 发件人邮箱
sender = "your\_email@example.com"
# 收件人邮箱
receivers = \["recipient\_email@example.com"]
# 邮件内容
message = MIMEText('邮件内容', 'plain', 'utf-8')
message\['From'] = Header("发件人姓名", 'utf-8')
message\['To'] = Header("收件人姓名", 'utf-8')
message\['Subject'] = Header("邮件主题", 'utf-8')
try:
    smtpObj = smtplib.SMTP('smtp.example.com', 587)
    smtpObj.starttls()
    smtpObj.login(sender, "password")
    smtpObj.sendmail(sender, receivers, message.as\_string())
    print("邮件发送成功")
except smtplib.SMTPException as e:
    print("Error: 无法发送邮件", e)

3. 批量重命名文件

利用os库对指定文件夹下的文件进行批量重命名。

import os
folder\_path = 'your\_folder\_path'
count = 1
for filename in os.listdir(folder\_path):
    if os.path.isfile(os.path.join(folder\_path, filename)):
        new\_name = f'new\_name\_{count}{os.path.splitext(filename)\[1]}'
        os.rename(os.path.join(folder\_path, filename), os.path.join(folder\_path, new\_name))
        count += 1

4. 数据清洗

使用pandas库对数据进行清洗,去除重复值、处理缺失值等。

import pandas as pd
df = pd.read\_csv('your\_data.csv')
# 去除重复行
df = df.drop\_duplicates()
# 处理缺失值,这里用0填充
df = df.fillna(0)
df.to\_csv('cleaned\_data.csv', index=False)

5. 生成 PPT

借助python-pptx库可以根据数据自动生成 PPT。

from pptx import Presentation
from pptx.util import Inches
prs = Presentation()
title\_slide\_layout = prs.slide\_layouts\[0]
slide = prs.slides.add\_slide(title\_slide\_layout)
title = slide.shapes.title
subtitle = slide.placeholders\[1]
title.text = "PPT标题"
subtitle.text = "PPT副标题"
# 后续可以添加更多内容,如图片、表格等
prs.save('test.pptx')

6. 自动化测试

使用Selenium库进行网页自动化测试。

from selenium import webdriver
driver = webdriver.Chrome()
driver.get('https://www.example.com')
# 查找元素并操作
element = driver.find\_element\_by\_id('element\_id')
element.click()
# 关闭浏览器
driver.quit()

7. 提取 PDF 文本

利用PyPDF2库提取 PDF 文件中的文本。

import PyPDF2
pdf\_file = open('your\_pdf.pdf', 'rb')
pdf\_reader = PyPDF2.PdfReader(pdf\_file)
text = ""
for page\_num in range(len(pdf\_reader.pages)):
    page = pdf\_reader.pages\[page\_num]
    text += page.extract\_text()
print(text)
pdf\_file.close()

8. 自动生成报表

结合pandasmatplotlib库,生成数据报表并可视化。

import pandas as pd
import matplotlib.pyplot as plt
df = pd.read\_csv('data.csv')
# 假设统计某列数据
data = df\['column\_name'].value\_counts()
data.plot(kind='bar')
plt.title('数据统计报表')
plt.xlabel('类别')
plt.ylabel('数量')
plt.savefig('report.png')

9. 自动化文件备份

使用shutil库实现文件的自动备份。

import shutil
import os
source\_folder = 'your\_source\_folder'
backup\_folder = 'your\_backup\_folder'
if not os.path.exists(backup\_folder):
    os.makedirs(backup\_folder)
for filename in os.listdir(source\_folder):
    file\_path = os.path.join(source\_folder, filename)
    if os.path.isfile(file\_path):
        shutil.copy2(file\_path, backup\_folder)

10. 任务调度

使用APScheduler库实现任务的定时执行,比如定时运行数据处理脚本。

from apscheduler.schedulers.blocking import BlockingScheduler
import your\_script
scheduler = BlockingScheduler()
# 每天凌晨1点执行任务
scheduler.add\_job(your\_script.run, 'cron', hour=1)
scheduler.start()

通过这些 Python 自动化办公案例,我们可以看到 Python 在提高办公效率方面的巨大潜力。

到此这篇关于10个Python自动化办公的脚本分享的文章就介绍到这了,更多相关Python自动化办公内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • python计算书页码的统计数字问题实例

    python计算书页码的统计数字问题实例

    这篇文章主要介绍了python计算书页码的统计数字问题实例,对比2个实例讲述了数字统计的技巧,非常实用,需要的朋友可以参考下
    2014-09-09
  • Python 使用 Pillow 模块给图片添加文字水印的方法

    Python 使用 Pillow 模块给图片添加文字水印的方法

    这篇文章主要介绍了Python 使用 Pillow 模块给图片添加文字水印的方法,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-08-08
  • Python实现多格式文本转为word

    Python实现多格式文本转为word

    在现代工作中,我们常常需要处理不同格式的文件,其中Word文档是最为常见的一种,本文主要介绍了如何使用Python创建一个全能的文件处理工具,能够将多种格式的文件转换为Word文档,需要的可以参考下
    2023-11-11
  • Python写的创建文件夹自定义函数mkdir()

    Python写的创建文件夹自定义函数mkdir()

    这篇文章主要介绍了Python写的创建文件夹自定义函数mkdir(),文件夹操作是编程中经常需要的,mkdir函数更是经典中的经典,需要的朋友可以参考下
    2014-08-08
  • 一文详解Django信号机制的工作原理

    一文详解Django信号机制的工作原理

    Django 信号(signals)是一种实现解耦的有力工具,它允许某些发生的事件通知其他部分的代码,本文将深入探讨 Django 信号的工作原理、如何定义和接收信号,以及如何在项目中有效地使用它们,需要的朋友可以参考下
    2023-11-11
  • Python使用pyautocad+openpyxl处理cad文件示例

    Python使用pyautocad+openpyxl处理cad文件示例

    这篇文章主要介绍了Python使用pyautocad+openpyxl处理cad文件,结合实例形式分析了Python使用pyautocad与openpyxl模块读写cad文件相关应用操作技巧,需要的朋友可以参考下
    2019-07-07
  • Python计算一个给定时间点前一个月和后一个月第一天的方法

    Python计算一个给定时间点前一个月和后一个月第一天的方法

    这篇文章主要介绍了Python计算一个给定时间点前一个月和后一个月第一天的方法,涉及Python使用datetime模块计算日期时间的相关操作技巧,需要的朋友可以参考下
    2018-05-05
  • 在Python中使用zlib模块进行数据压缩的教程

    在Python中使用zlib模块进行数据压缩的教程

    这篇文章主要介绍了在Python中使用zlib模块进行数据压缩的教程,是Python入门学习中的基础知识,需要的朋友可以参考下
    2015-06-06
  • python scapy抓包获取udp并转发的操作步骤

    python scapy抓包获取udp并转发的操作步骤

    这篇文章主要介绍了python scapy抓包获取udp并转发的操作步骤,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
    2024-01-01
  • 使用Pytorch+PyG实现MLP的详细过程

    使用Pytorch+PyG实现MLP的详细过程

    图神经网络是最近 AI 领域最热门的方向之一,下面这篇文章主要给大家介绍了关于使用Pytorch+PyG实现MLP的详细过程,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2023-03-03

最新评论