百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

这五个办公室常用自动化工具python源码,复制代码就能用

off999 2025-06-28 15:52 32 浏览 0 评论

办公室自动化

现在能看这文章的恐怕大部分都是办公室久坐工作者,很多都有腰肌劳损、肩周炎等职业病,难道就不能有个工具缓解一下工作量吗?

那么恭喜你点进了这篇文章,这篇文章将使用 python 直接实现五个常用自动化脚本,你仅需要复制、粘贴就可以使用,非常方便。

1. 批量文件重命名

代码

# -*- coding: utf-8 -*-
import os
import argparse


def batch_rename_files(folder_path, prefix):
    for count, filename in enumerate(os.listdir(folder_path)):
        dst = f'{prefix}_{str(count)}.{filename.split(".")[-1]}'
        print(f'正在将 {filename} 重命名为 {dst}')
        src = os.path.join(folder_path, filename)
        dst = os.path.join(folder_path, dst)
        os.rename(src, dst)


if __name__ == '__main__':
    parser = argparse.ArgumentParser(
        prog='文件批量重命名',
        description='重命名对应文件夹内所有文件',
    )
    parser.add_argument('-p', '--path', type=str, help='文件夹路径')
    parser.add_argument('-n', '--name', type=str, help='重命名名称')

    args = parser.parse_args()

    folder_path = args.path
    name = args.name if args.name is not None else '未命名'
    if folder_path is None:
        print('缺失文件夹路径')
    elif not os.path.exists(folder_path):
        print('文件夹不存在')
    elif not os.path.isdir(folder_path):
        print('不是文件夹')
    else:
        print('开始重命名...')
        batch_rename_files(folder_path, name)

调用信息

usage: 文件批量重命名 [-h] [-p PATH] [-n NAME]

重命名对应文件夹内所有文件

optional arguments:
  -h, --help            show this help message and exit
  -p PATH, --path PATH  文件夹路径
  -n NAME, --name NAME  重命名名称

调用示例

python xx.py -p 文件夹路径

2. 批量图片生成pdf

安装

pip install Pillow reportlab

代码

# -*- coding: utf-8 -*-
import os
import argparse
from reportlab.lib.pagesizes import A4
from reportlab.pdfgen import canvas
from PIL import Image


def images_to_pdf_a4(folder_path, output_pdf):
    valid_exts = ('.jpg', '.jpeg', '.png', '.gif', '.bmp', '.tiff')
    image_files = sorted(
        [f for f in os.listdir(folder_path) if f.lower().endswith(valid_exts)],
        key=lambda x: x.lower()
    )

    if not image_files:
        print('错误:未找到图片文件。')
        return

    c = canvas.Canvas(output_pdf, pagesize=A4)
    a4_width, a4_height = A4

    y_position = a4_height
    for img_file in image_files:
        img_path = os.path.join(folder_path, img_file)
        try:
            img = Image.open(img_path)
            img_width, img_height = img.size
            # 计算缩放比例以适合A4页面
            scale = min(a4_width / img_width, a4_height / img_height)
            scaled_w = img_width * scale
            scaled_h = img_height * scale
            # 居中坐标
            x = (a4_width - scaled_w) / 2

            if y_position - scaled_h < 0:
                c.showPage()  # 空间不足时换页
                y_position = a4_height  # 重置Y坐标

            y = y_position - scaled_h

            # 绘制图片并添加新页面
            c.drawImage(img_path, x, y, scaled_w, scaled_h)
            y_position = y
        except Exception as e:
            print(f'跳过文件 {img_file}: {e}')

    c.save()
    print(f'成功生成A4版pdf:{output_pdf}')


if __name__ == '__main__':
    parser = argparse.ArgumentParser(
        prog='批量图片pdf生成',
        description='对应文件夹内所有图片生成pdf',
    )
    parser.add_argument('-p', '--path', type=str, help='图片文件夹路径')
    parser.add_argument('-n', '--name', type=str, help='pdf名称')

    args = parser.parse_args()

    folder_path = args.path
    name = args.name if args.name is not None else '未命名'
    if folder_path is None:
        print('缺失文件夹路径')
    elif not os.path.exists(folder_path):
        print('文件夹不存在')
    elif not os.path.isdir(folder_path):
        print('不是文件夹')
    else:
        print('开始生成pdf...')
        images_to_pdf_a4(folder_path, f'{name}.pdf')

调用信息

usage: 批量图片pdf生成 [-h] [-p PATH] [-n NAME]

对应文件夹内所有图片生成pdf

optional arguments:
  -h, --help            show this help message and exit
  -p PATH, --path PATH  图片文件夹路径
  -n NAME, --name NAME  pdf名称

调用示例

python xx.py -p 文件夹路径

3. 批量生成二维码

安装

pip install qrcode

代码

# -*- coding: utf-8 -*-
import os
import argparse
import qrcode
import shutil


def generate_qr_code(data, output_file):
    qr = qrcode.QRCode(
        version=1,
        error_correction=qrcode.constants.ERROR_CORRECT_L,
        box_size=10,
        border=4,
    )
    qr.add_data(data)
    qr.make(fit=True)

    img = qr.make_image(fill_color="black", back_color="white")
    img.save(output_file)


if __name__ == '__main__':
    parser = argparse.ArgumentParser(
        prog='txt批量生成二维码',
        description='将txt文件的内容批量生成二维码',
    )
    parser.add_argument('-p', '--path', type=str, help='txt文件路径')
    parser.add_argument('-o', '--output', type=str, help='导出文件夹名称')

    args = parser.parse_args()

    txt_path = args.path
    output = args.output if args.output is not None else 'output'
    if txt_path is None:
        print('缺失txt文件路径')
    elif not os.path.exists(txt_path):
        print('txt文件不存在')
    elif not txt_path.endswith('.txt'):
        print('不是txt文件')
    else:
        print('开始生成二维码...')

        if not os.path.exists(output):
            os.makedirs(output)
        else:
            shutil.rmtree(output)
            os.makedirs(output)

        with open(txt_path, 'r', encoding='utf-8') as f:
            for line in f:
                name = line.replace('.', '_').replace('\n', '')
                file_path = os.path.join(output, f'{name}.png')
                generate_qr_code(line, file_path)
                print(f'{name} 生成二维码完成')

调用信息

usage: txt批量生成二维码 [-h] [-p PATH] [-o OUTPUT]

将txt文件的内容批量生成二维码

optional arguments:
  -h, --help            show this help message and exit
  -p PATH, --path PATH  txt文件路径
  -o OUTPUT, --output OUTPUT
                        导出文件夹名称

调用示例

python xx.py -p xxxxxx.txt

文件示例

txt文件

4. 批量excel合并一个文件

安装

pip install pandas

代码

# -*- coding: utf-8 -*-
import os
import argparse
import pandas as pd


def merge_excel_files(folder_path, output_file):
    all_data = pd.DataFrame()
    for file in os.listdir(folder_path):
        if file.endswith('.xlsx'):
            file_path = os.path.join(folder_path, file)
            df = pd.read_excel(file_path)
            all_data = pd.concat([all_data, df], ignore_index=True)
    all_data.to_excel(output_file, index=False)


if __name__ == '__main__':
    parser = argparse.ArgumentParser(
        prog='excel文件合并',
        description='将文件夹内所有.xlsx文件合并到一个文件中',
    )
    parser.add_argument('-p', '--path', type=str, help='文件夹路径')
    parser.add_argument('-n', '--name', type=str, help='合并文件名称')

    args = parser.parse_args()

    folder_path = args.path
    name = args.name if args.name is not None else '合并文件'
    if folder_path is None:
        print('缺失文件夹路径')
    elif not os.path.exists(folder_path):
        print('文件夹不存在')
    elif not os.path.isdir(folder_path):
        print('不是文件夹')
    else:
        print('开始合并excel...')
        file_name = f'{name}.xlsx'
        merge_excel_files(folder_path, file_name)
        print(f'{file_name} 合并完成')

调用信息

usage: excel文件合并 [-h] [-p PATH] [-n NAME]

将文件夹内所有.xlsx文件合并到一个文件中

optional arguments:
  -h, --help            show this help message and exit
  -p PATH, --path PATH  文件夹路径
  -n NAME, --name NAME  合并文件名称

调用示例

python xx.py -p 文件夹路径

5. 批量去除图片背景

安装

pip install rembg Pillow onnxruntime

代码

# -*- coding: utf-8 -*-
import os
import argparse
from rembg import remove


def remove_background(input_folder, output_folder):
    # 确保输出文件夹存在
    if not os.path.exists(output_folder):
        os.makedirs(output_folder)

    # 遍历输入文件夹中的所有文件
    for filename in os.listdir(input_folder):
        if filename.lower().endswith(('.png', '.jpg', '.jpeg', '.bmp', '.gif')):
            # 构建输入和输出文件的完整路径
            input_path = os.path.join(input_folder, filename)
            output_path = os.path.join(output_folder, filename)

            # 打开图片并去除背景
            with open(input_path, 'rb') as input_file:
                input_image = input_file.read()
                output_image = remove(input_image)

            # 保存去除背景后的图片
            with open(output_path, 'wb') as output_file:
                output_file.write(output_image)

            print(f"去除背景完成: {filename}")


if __name__ == '__main__':
    parser = argparse.ArgumentParser(
        prog='excel文件合并',
        description='将文件夹内所有.xlsx文件合并到一个文件中',
    )
    parser.add_argument('-p', '--path', type=str, help='文件夹路径')
    parser.add_argument('-o', '--output', type=str, help='导出文件夹名称')

    args = parser.parse_args()

    folder_path = args.path
    output = args.output if args.output is not None else 'output'
    if folder_path is None:
        print('缺失文件夹路径')
    elif not os.path.exists(folder_path):
        print('文件夹不存在')
    elif not os.path.isdir(folder_path):
        print('不是文件夹')
    else:
        print('开始去除背景...')
        remove_background(folder_path, output)

调用信息

usage: excel文件合并 [-h] [-p PATH] [-o OUTPUT]

将文件夹内所有.xlsx文件合并到一个文件中

optional arguments:
  -h, --help            show this help message and exit
  -p PATH, --path PATH  文件夹路径
  -o OUTPUT, --output OUTPUT
                        导出文件夹名称

调用示例

python xx.py -p 文件夹路径

结尾

工作中五个常用工具的源码已经提供了,怎么使用需要你来支配。当然还有很多工具在这里没有提供,如果你有需要其他的或者有更好的可以在下方进行留言。

相关推荐

ipad越狱的好处与坏处(ipad越狱好不好)

  好处一:  1、重命名、重组应用程序  如果你看着Sparrow(iOS最优秀邮件客户端)这个名字不爽,越狱之后就可以改成“Email”,如果你觉得“豆瓣电台”这个名字不给力,那就改成“中央人民广...

win7光盘重装系统步骤图解(win7光盘如何重装系统)

1.确认您的电脑支持从光盘启动。如果支持,可以直接将Windows7安装光盘插入电脑的光驱中。 2.打开电脑,按下F2、F10、F12或Delete等键进入BIOS设置界面。 ...

电脑已联网却无法上网(电脑已经联网了但是不能上网)

电脑连上网后,仍可能存在无法上网的情况,这可能是由多种原因造成的。以下是一些可能的原因和解决方法:1.浏览器问题:有时候,浏览器可能会出现故障,导致无法正常访问网络。您可以尝试清除浏览器的缓存和co...

u盘价格一览表(u盘单价)

不同品牌价格不同,不同内存价格也不同,例如8g、16g、32g、64g等多种容量大小的,根据容量的不同,报价在29元到120元之间不等。闪存盘虽然小,但相对来说却有很大的存储容量。U盘大多能够存储比一...

windows查看ip命令(windows如何查看ip地址)

查看电脑IP:    1)使用Windows+R键打开“运行”窗口,然后输入CMD进入命令提示窗口2)进入命令窗口之后,输入:ipconfig/all回车即可...

内存条的作用(内存条的作用和参数配置)

内存条是存储电脑运行所需的数据和程序,帮助CPU快速读取和运行,提高计算机的运行速度和处理能力。内存条也被称为随机存取存储器(RAM),是电脑中非常必要的一个组件。常见的内存条类型有DDR、DDR2、...

autocad2012安装失败(autocad2012无法安装)

如果您遇到CAD2012安装不了的问题,可能有几个原因导致这种情况。以下是一些常见的解决方法:1.确保系统要求:首先,请确保您的计算机符合CAD2012的系统要求。检查您的操作系统版本、内存、处理器...

win11 16g内存最佳虚拟内存(window10 16个g虚拟内存设置)

内存足够大可以将系统的虚拟内存关掉。1、鼠标右键【此电脑】,在菜单中选择【属性】。2、进入属性后,点击【高级系统设置】。3、进入系统属性后,点击高级下面的【设置】。4、进入性能设置后,点击【高级】。5...

查看windows7激活码(win7激活码哪里看)

windows7激活密钥如下:PPBK3-M92CH-MRR9X-34Y9P-7CH2FQ8JXJ-8HDJR-X4PXM-PW99R-KTJ3H8489X-THF3D-BDJQR-D27PH-P...

win10商业版和消费者版区别(win10商业版与消费者版)

1、用户群体的区别消费者版:通俗来说就是零售版,是一个非常适合个人用户和家庭用户购买的版本。商业版:适合大客户使用的版本,而且还比较适合企业用户使用以及进行批量部署。2、版本区别消费者版Consume...

bilibili加速器(bilibili加速器手机版官网)

需要在电脑上使用bilibili加速器,因为手机上bilibili已经有自带的加速器功能了。可以在bilibili官网或者一些应用商店下载使用,下完后按照安装提示进行安装即可。如果使用的是第三方软件,...

电脑自带的清理垃圾的工具(电脑自带的清理垃圾的工具叫什么)

CCleaner是一款免费的系统优化和隐私保护工具,它的体积小、扫描速度非常快,支持自定义清理规则,增强了应用程序清理范围和效果。CCleaner是Piriform(梨子公司)最著名广受好评的系统清理...

笔记本电脑用什么下载软件(笔记本电脑用什么下载软件比较好)
  • 笔记本电脑用什么下载软件(笔记本电脑用什么下载软件比较好)
  • 笔记本电脑用什么下载软件(笔记本电脑用什么下载软件比较好)
  • 笔记本电脑用什么下载软件(笔记本电脑用什么下载软件比较好)
  • 笔记本电脑用什么下载软件(笔记本电脑用什么下载软件比较好)
如何设置本地连接

在“控制面板”中,选择“网络和Internet”>“网络和共享中心”。在左侧窗格中,选择“更改适配器设置”。在“网络连接”窗口中,右键单击“本地连接”,然后选择“属性”。在“本地连接...

office2007官方免费版安装包
  • office2007官方免费版安装包
  • office2007官方免费版安装包
  • office2007官方免费版安装包
  • office2007官方免费版安装包

取消回复欢迎 发表评论: