欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python自動(dòng)化辦公中的應(yīng)用說明和腳本示例

 更新時(shí)間:2025年08月30日 14:58:20   作者:點(diǎn)云SLAM  
Python在自動(dòng)化辦公中的應(yīng)用非常廣泛,Python?自動(dòng)化辦公包括:文檔處理(Word/Excel)、郵件處理、PDF?操作、文件整理、數(shù)據(jù)采集與報(bào)表、人工流程替代等,Python自動(dòng)化常用庫包括openpyxl、pandas、docx、smtplib、imaplib、pyautogui、pdfplumber、PyPDF2、schedule

Python 在自動(dòng)化辦公中的應(yīng)用非常廣泛,可大幅減少重復(fù)性操作,提升辦公效率。Python 自動(dòng)化辦公包括:文檔處理(Word/Excel)、郵件處理、PDF 操作、文件整理、數(shù)據(jù)采集與報(bào)表、人工流程替代等。Python自動(dòng)化常用庫包括openpyxl、pandas、docx、smtplib、imaplib、pyautogui、pdfplumber、PyPDF2、schedule。

本文全面的講解Python自動(dòng)化辦公,并附帶多個(gè)常用場景的 代碼示例。

一、自動(dòng)化辦公能做什么?

任務(wù)類型示例功能
文檔處理(Word/Excel)生成報(bào)告、批量修改、數(shù)據(jù)填充
郵件處理自動(dòng)發(fā)郵件、收郵件、附件下載
PDF 操作拆分、合并、加密、提取文本
文件整理批量重命名、分類移動(dòng)、自動(dòng)歸檔
數(shù)據(jù)采集與報(bào)表從網(wǎng)頁抓取數(shù)據(jù),生成日?qǐng)?bào)或周報(bào)
人工流程替代自動(dòng)點(diǎn)擊、填表、模擬人工輸入(結(jié)合 pyautogui)

二、Python 自動(dòng)化常用庫一覽

庫名用途
openpyxl操作 Excel(.xlsx
pandas表格數(shù)據(jù)處理
docx操作 Word 文檔
smtplib發(fā)送郵件
imaplib接收郵件
pyautogui模擬鼠標(biāo)鍵盤操作
pdfplumber提取 PDF 文本內(nèi)容
PyPDF2拆分/合并 PDF
schedule定時(shí)任務(wù)

三、典型場景代碼示例

1. 批量生成 Excel 報(bào)表(openpyxl)

from openpyxl import Workbook

data = [
    ['姓名', '部門', '成績'],
    ['張三', '銷售部', 89],
    ['李四', '技術(shù)部', 95]
]

wb = Workbook()
ws = wb.active
ws.title = "員工成績表"

for row in data:
    ws.append(row)

wb.save("員工成績表.xlsx")
print(" Excel 報(bào)表已生成。")

2. 自動(dòng)發(fā)送郵件(帶附件)

import smtplib
from email.message import EmailMessage

msg = EmailMessage()
msg['Subject'] = '日?qǐng)?bào) - 自動(dòng)發(fā)送'
msg['From'] = 'your_email@example.com'
msg['To'] = 'receiver@example.com'
msg.set_content('請(qǐng)查收今日日?qǐng)?bào),見附件。')

# 添加附件
with open('日?qǐng)?bào).xlsx', 'rb') as f:
    msg.add_attachment(f.read(), maintype='application',
                       subtype='vnd.openxmlformats-officedocument.spreadsheetml.sheet',
                       filename='日?qǐng)?bào).xlsx')

# 發(fā)送郵件(使用QQ郵箱為例)
with smtplib.SMTP_SSL('smtp.qq.com', 465) as smtp:
    smtp.login('your_email@example.com', 'your_app_password')
    smtp.send_message(msg)

print(" 郵件已發(fā)送。")

3. 批量提取 PDF 文本(pdfplumber)

import pdfplumber

with pdfplumber.open('文件.pdf') as pdf:
    all_text = ''
    for page in pdf.pages:
        all_text += page.extract_text() + '\n'

with open('提取內(nèi)容.txt', 'w', encoding='utf-8') as f:
    f.write(all_text)

print(" PDF 文本已提取。")

4. 自動(dòng)打開網(wǎng)頁、模擬輸入(pyautogui + webbrowser)

import webbrowser
import pyautogui
import time

# 打開網(wǎng)頁
webbrowser.open('https://www.google.com')
time.sleep(3)  # 等待頁面加載

# 模擬輸入搜索內(nèi)容
pyautogui.write('Python automation', interval=0.1)
pyautogui.press('enter')

print(" 自動(dòng)搜索已完成。")

5. 定時(shí)任務(wù)(schedule)

import schedule
import time

def job():
    print("現(xiàn)在是:", time.strftime("%H:%M:%S"), " → 執(zhí)行任務(wù)")

# 每天早上 9 點(diǎn)執(zhí)行
schedule.every().day.at("09:00").do(job)

while True:
    schedule.run_pending()
    time.sleep(1)

四、組合案例:自動(dòng)發(fā)送日?qǐng)?bào)

假設(shè)你有一個(gè) Excel 日?qǐng)?bào),每天生成并通過郵件發(fā)送:

  1. openpyxl 創(chuàng)建日?qǐng)?bào)
  2. smtplib 發(fā)送郵件
  3. schedule 定時(shí)運(yùn)行
  4. 也可打包為 .exe 實(shí)現(xiàn)傻瓜式執(zhí)行(使用 pyinstaller

五、提升建議

  • 使用 logging 模塊記錄日志
  • 配合 TkinterPyQt 做可視化界面
  • 寫成函數(shù)模塊,支持定制化
  • 學(xué)會(huì)使用任務(wù)計(jì)劃(Windows)或 crontab(Linux/macOS)

批量處理 Excel 文件是辦公自動(dòng)化中非常常見的需求,比如:

  • 讀取多個(gè) Excel 文件中的數(shù)據(jù)并合并
  • 批量修改單元格內(nèi)容
  • 提取指定字段后導(dǎo)出為新表
  • 批量生成報(bào)表

六、擴(kuò)展:批量處理Excel

適用場景

場景示例
批量讀取多個(gè) Excel 文件合并多個(gè)日?qǐng)?bào)、月報(bào)文件為一個(gè)總表
批量修改某列修改“狀態(tài)”列中的“未完成”為“完成”
按條件提取或匯總數(shù)據(jù)提取銷售額大于 1 萬的記錄
批量寫入、創(chuàng)建新表每人生成一個(gè)專屬工作表

常用庫安裝

pip install openpyxl pandas

批量處理 Excel 文件代碼示例

示例 1:批量合并多個(gè) Excel 表格

功能:將某個(gè)文件夾下所有 .xlsx 文件合并為一個(gè)總表

import pandas as pd
import os

folder = './excel_files'  # Excel 文件所在文件夾
output_file = '合并結(jié)果.xlsx'

all_data = []

for file in os.listdir(folder):
    if file.endswith('.xlsx'):
        file_path = os.path.join(folder, file)
        df = pd.read_excel(file_path)
        df['來源文件'] = file  # 可選:添加來源文件列
        all_data.append(df)

# 合并所有數(shù)據(jù)
merged_df = pd.concat(all_data, ignore_index=True)
merged_df.to_excel(output_file, index=False)

print(" 所有 Excel 文件已合并到:", output_file)

示例 2:批量修改某一列中的值(如“狀態(tài)”列)

import pandas as pd
import os

folder = './excel_files'

for file in os.listdir(folder):
    if file.endswith('.xlsx'):
        path = os.path.join(folder, file)
        df = pd.read_excel(path)

        # 修改 “狀態(tài)” 列中的“未完成”為“完成”
        df['狀態(tài)'] = df['狀態(tài)'].replace('未完成', '完成')

        # 保存覆蓋原文件
        df.to_excel(path, index=False)
        print(f" 已修改:{file}")

示例 3:按字段篩選并保存為新表

import pandas as pd
import os

input_file = '員工信息表.xlsx'
df = pd.read_excel(input_file)

# 篩選工資大于10000的員工
filtered = df[df['工資'] > 10000]

filtered.to_excel('高薪員工.xlsx', index=False)
print(" 篩選結(jié)果已保存。")

示例 4:為每位員工生成單獨(dú) Excel 表

import pandas as pd
import os

df = pd.read_excel('員工信息.xlsx')

output_dir = './員工報(bào)表'
os.makedirs(output_dir, exist_ok=True)

# 按“姓名”分組,每個(gè)員工一個(gè)文件
for name, group in df.groupby('姓名'):
    filename = os.path.join(output_dir, f'{name}_報(bào)表.xlsx')
    group.to_excel(filename, index=False)
    print(f" 已生成:{filename}")

進(jìn)階建議

  • Tkinter 加上文件夾選擇、按鈕,做成 GUI 工具
  • 加日志記錄:每次處理記錄時(shí)間、文件名
  • 使用定時(shí)器 + 自動(dòng)郵件發(fā)送,形成完整自動(dòng)報(bào)表流程
  • 使用 openpyxl 更細(xì)粒度控制樣式、顏色、單元格合并等

自動(dòng)清洗多個(gè) Excel 表中的重復(fù)數(shù)據(jù)示例:

下面是自動(dòng)遍歷一個(gè)文件夾下的多個(gè) Excel 文件,按指定的列去重,并把清洗后的結(jié)果另存到一個(gè)新文件夾Python腳本。

腳本示例(Python 3 + pandas)

import os
import pandas as pd

# === 配置區(qū)域 ===
input_folder = r"./excel_input"       # 待處理Excel文件所在文件夾
output_folder = r"./excel_output"     # 清洗后文件保存文件夾
subset_columns = None                 # 去重依據(jù)的列,例如 ["姓名", "身份證號(hào)"],None表示全列去重
keep_rule = "first"                   # 保留規(guī)則: "first" 保留首次出現(xiàn), "last" 保留最后一次, False 保留所有重復(fù)(不常用)

# 創(chuàng)建輸出文件夾
os.makedirs(output_folder, exist_ok=True)

# 遍歷文件夾中的所有Excel文件
for filename in os.listdir(input_folder):
    if filename.lower().endswith((".xls", ".xlsx")):
        file_path = os.path.join(input_folder, filename)
        
        try:
            # 讀取Excel(保留所有sheet)
            xls = pd.ExcelFile(file_path)
            cleaned_sheets = {}
            
            for sheet_name in xls.sheet_names:
                df = pd.read_excel(xls, sheet_name=sheet_name)
                
                # 去重
                before_rows = len(df)
                df_cleaned = df.drop_duplicates(subset=subset_columns, keep=keep_rule)
                after_rows = len(df_cleaned)
                
                print(f"{filename} - {sheet_name}: {before_rows} -> {after_rows} 行")
                
                cleaned_sheets[sheet_name] = df_cleaned
            
            # 保存清洗后的文件
            output_path = os.path.join(output_folder, filename)
            with pd.ExcelWriter(output_path, engine="openpyxl") as writer:
                for sheet_name, df_cleaned in cleaned_sheets.items():
                    df_cleaned.to_excel(writer, sheet_name=sheet_name, index=False)
        
        except Exception as e:
            print(f"處理文件 {filename} 時(shí)出錯(cuò): {e}")

print(" 數(shù)據(jù)清洗完成!")

七、總結(jié)

到此這篇關(guān)于Python自動(dòng)化辦公中的應(yīng)用說明和腳本示例的文章就介紹到這了,更多相關(guān)python自動(dòng)化辦公腳本內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 基于Python制作簡單的IP查詢工具

    基于Python制作簡單的IP查詢工具

    這篇文章主要為大家詳細(xì)介紹了如何基于Python制作一個(gè)簡單的IP查詢工具,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2024-03-03
  • Python編程mac下使用pycharm小技巧

    Python編程mac下使用pycharm小技巧

    這篇文章主要介紹了Python編程中在mac下使用pycharm的一些小技巧,建議正在使用Pycharm的同學(xué)們可以收藏閱讀,可以節(jié)省你的編程時(shí)間
    2021-09-09
  • python實(shí)現(xiàn)優(yōu)雅的打印json格式文本

    python實(shí)現(xiàn)優(yōu)雅的打印json格式文本

    這篇文章主要介紹了python實(shí)現(xiàn)優(yōu)雅的打印json格式文本方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-08-08
  • 判斷python字典中key是否存在的兩種方法

    判斷python字典中key是否存在的兩種方法

    這篇文章主要介紹了判斷python字典中key是否存在的兩種方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-08-08
  • Python數(shù)據(jù)標(biāo)準(zhǔn)化的實(shí)例分析

    Python數(shù)據(jù)標(biāo)準(zhǔn)化的實(shí)例分析

    在本篇文章里小編給大家整理了關(guān)于Python數(shù)據(jù)標(biāo)準(zhǔn)化的實(shí)例內(nèi)容,有需要的朋友們可以測試學(xué)習(xí)下。
    2021-08-08
  • Python+eval函數(shù)實(shí)現(xiàn)動(dòng)態(tài)地計(jì)算數(shù)學(xué)表達(dá)式詳解

    Python+eval函數(shù)實(shí)現(xiàn)動(dòng)態(tài)地計(jì)算數(shù)學(xué)表達(dá)式詳解

    Python的 eval() 允許從基于字符串或基于編譯代碼的輸入中計(jì)算任意Python表達(dá)式。當(dāng)從字符串或編譯后的代碼對(duì)象的任何輸入中動(dòng)態(tài)計(jì)算Python表達(dá)式時(shí),此函數(shù)非常方便。本文將利用eval實(shí)現(xiàn)動(dòng)態(tài)地計(jì)算數(shù)學(xué)表達(dá)式,需要的可以參考一下
    2022-09-09
  • Python日志采集代碼詳解

    Python日志采集代碼詳解

    這篇文章主要介紹了Python日志采集,在實(shí)際使用python做自動(dòng)化測試過程中兩種解決思路都可以使用,且都挺方便,其中對(duì)于思路1,還可以將代碼進(jìn)行更進(jìn)一步的封裝,需要的朋友可以參考下
    2022-05-05
  • Django2.1.7 查詢數(shù)據(jù)返回json格式的實(shí)現(xiàn)

    Django2.1.7 查詢數(shù)據(jù)返回json格式的實(shí)現(xiàn)

    這篇文章主要介紹了Django2.1.7 查詢數(shù)據(jù)返回json格式的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12
  • Python?RawString與open文件的newline換行符遇坑解決

    Python?RawString與open文件的newline換行符遇坑解決

    這篇文章主要為大家介紹了Python?RawString與open文件的newline換行符遇坑解決示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-10-10
  • python提取視頻中的音頻的實(shí)現(xiàn)示例

    python提取視頻中的音頻的實(shí)現(xiàn)示例

    MoviePy是一個(gè)用于視頻編輯的庫,它可以提取視頻中的音頻并保存為音頻文件,本文主要介紹了python提取視頻中的音頻的實(shí)現(xiàn)示例,感興趣的可以了解一下
    2024-03-03

最新評(píng)論