Python实现批量生成,重命名和删除word文件
作者:魔都吴所谓 发布时间:2022-12-03 05:51:33
批量生成word文件
场景:需要新建多个类似文件名
比如:今天的事例是新建12个文件名为:
保安员考试试卷1及答案.docx
保安员考试试卷2及答案.docx
...
保安员考试试卷12及答案.docx
痛点:
手动操作重复性高,出错率高,易造成人疲劳,降低效率;
安装
pip install python-docx
log
(env_qt) D:\code\qt_demo\demo>pip install python-docx
Looking in indexes: pypi.tuna.tsinghua.edu.cn/simple
Collecting python-docx
Using cached pypi.tuna.tsinghua.edu.cn/packages/8b…
33/python-docx-0.8.11.tar.gz (5.6 MB)
Preparing metadata (setup.py) ... done
Collecting lxml>=2.3.2
Downloading pypi.tuna.tsinghua.edu.cn/packages/39…
8/lxml-4.9.2-cp39-cp39-win_amd64.whl (3.9 MB)
---------------------------------------- 3.9/3.9 MB 1.4 MB/s eta 0:00:00
Building wheels for collected packages: python-docx
Building wheel for python-docx (setup.py) ... done
Created wheel for python-docx: filename=python_docx-0.8.11-py3-none-any.whl size=184519 sha256=595cd9888a3832964d8f2477f
fd5325f596549da8c1dd305e63d5f7b3d24884c
Stored in directory: c:\users\wz\appdata\local\pip\cache\wheels\39\ca\c1\d3e7abe5ce2e8423382d816e689c056bc26590f48fad8f2
0ac
Successfully built python-docx
Installing collected packages: lxml, python-docx
Successfully installed lxml-4.9.2 python-docx-0.8.11
[notice] A new release of pip available: 22.3.1 -> 23.0.1
[notice] To update, run: python.exe -m pip install --upgrade pip
(env_qt) D:\code\qt_demo\demo>****
官方文档:
https://python-docx.readthedocs.io/en/latest/index.html
三方库引入
import os
from docx import Document
解释:
1.在文件路径下会获取文件夹下面所有文件,使用os
模块;
2.word文档的相关操作使用docx
模块;
批量新建文件名
场景:需要新建多个类似文件名
比如:今天的事例是新建12个文件名为:
保安员考试试卷1及答案.docx
保安员考试试卷2及答案.docx
...
保安员考试试卷12及答案.docx
痛点:
手动操作重复性高,出错率高,易造成人疲劳,降低效率;
def gen_names(pre_fix, num):
"""
批量生成文件名
:param pre_fix: 文件名的前缀
:param num: 文件数量
:return:name_list :文件名列表(所有要生成的文件名)
"""
print("生成文件名列表开始")
name_list = []
for i in range(1, num + 1):
tmp = pre_fix + str(i)
name_list.append(tmp)
print("生成文件名列表结束")
return name_list
生成word文件
生成单个文件
def new_one_file(document, name):
"""
生成单个文件
:param document:
:param name: 文件名
:return:
"""
print("单个生成文件开始")
document.save(name + '.docx')
print("单个生成文件结束")
生成多个文件
def new_many_file(document, names):
"""
生成多个文件
:param document: Document实例对象
:param names:多个文件的文件名
:return:
"""
print("批量生成文件开始")
for name in names:
document.save(os.path.join("tmp", name + '.docx'))
print("批量生成文件结束")
重命名文件
def rename_file(path):
"""
将path路径下的文件都重命名
规则:在原文件名后面加上 ---> "及答案." 字段
:param path:
:return:
"""
print("重命名开始")
files = os.listdir(path)
for file in files:
name, doc_type = file.split(".")
new_name = os.path.join(path, name + "及答案." + doc_type)
file_tmp = os.path.join(path, file)
# 语法:
# os.rename(src, dst) :用于命名文件或目录
# src:需要修改的文件或目录名。
# dst:修改后的文件或目录名。
os.rename(file_tmp, new_name)
print("重命名结束")
删除文件
def del_files(path):
"""
删除指定路径下的文件
:param path:
:return:
"""
print("删除开始")
files = os.listdir(path)
for file in files:
os.remove(os.path.join(path, file))
print("删除成功")
函数调用
if __name__ == '__main__':
path = r"C:\Users\wz\Desktop\保安员考试试卷"
document = Document()
pre_fix = "保安员考试"
# name_all = gen_names(pre_fix, 10)
# new_many_file(document, name_all)
# rename_file("tmp")
del_files("tmp")
效果展示
批量生成文件
批量重命名文件
删除文件
所有代码
import os
from docx import Document
def gen_names(pre_fix, num):
"""
批量生成文件名
:param pre_fix: 文件名的前缀
:param num: 文件数量
:return:name_list :文件名列表(所有要生成的文件名)
"""
print("生成文件名列表开始")
name_list = []
for i in range(1, num + 1):
tmp = pre_fix + str(i)
name_list.append(tmp)
print("生成文件名列表结束")
return name_list
def new_one_file(document, name):
"""
生成单个文件
:param document:
:param name: 文件名
:return:
"""
print("单个生成文件开始")
document.save(name + '.docx')
print("单个生成文件结束")
def new_many_file(document, names):
"""
生成多个文件
:param document: Document实例对象
:param names:多个文件的文件名
:return:
"""
print("批量生成文件开始")
for name in names:
document.save(os.path.join("tmp", name + '.docx'))
print("批量生成文件结束")
def rename_file(path):
"""
将path路径下的文件都重命名
规则:在原文件名后面加上 ---> "及答案." 字段
:param path:
:return:
"""
print("重命名开始")
files = os.listdir(path)
for file in files:
name, doc_type = file.split(".")
new_name = os.path.join(path, name + "及答案." + doc_type)
file_tmp = os.path.join(path, file)
# 语法:
# os.rename(src, dst) :用于命名文件或目录
# src:需要修改的文件或目录名。
# dst:修改后的文件或目录名。
os.rename(file_tmp, new_name)
print("重命名结束")
def del_files(path):
"""
删除指定路径下的文件
:param path:
:return:
"""
print("删除开始")
files = os.listdir(path)
for file in files:
os.remove(os.path.join(path, file))
print("删除成功")
if __name__ == '__main__':
path = r"C:\Users\wz\Desktop\保安员考试试卷"
document = Document()
pre_fix = "保安员考试"
# 生成多个文件名
# name_all = gen_names(pre_fix, 10)
#创建多个文件
# new_many_file(document, name_all)
# 重命名文件
# rename_file("tmp")
# 删除文件
del_files("tmp")
来源:https://juejin.cn/post/7206487695123972155


猜你喜欢
- 原文地址https://www.codementor.io/python/tutorial/advanced-use-python-deco
- 这篇文章主要介绍了python代码如何实现余弦相似性计算,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的
- Python 输出 "Hello, World!",英文没有问题,但是如果你输出中文字符"你好,世界"
- declare @id  
- 快速搭建scrapy开发环境pythonpippip百度网盘注:不同的电脑上所带有环境不同,安装方式有些许差别1、成功安装python并添加
- 如下所示:try:a=1except Exception as e: print (e)import tracebackimport sys
- 首先,我们看看models.py里的模型,有个upload_to参数,为了和过去一刀两断,楼主决定给upload_to赋值一个新的值叫ava
- 基础这个模块是socket的异步实现,让我们先来熟悉一下模块中的一些类和方法:1.asyncore.loop输入一个轮询循环直到通过计数或打
- 如下所示:import numpy as npimport pandas as pdfrom pandas import Series,Da
- 先来看一段代码:# ~*~ Twisted - A Python tale ~*~from time import sleep# Hello
- perl用的最多的地方就算是文件处理了,下面我就总结了一下perl文件操作的一些东西,并且有具体的例子,通过下面的例子,加强我们对perl文
- 首先你得引入bootstrap与jquery推荐一个CDN:http://cdn.gbtags.com/index.html然后就是开始编写
- 本文实例为大家分享了vue实现消息无缝滚动效果的具体代码,供大家参考,具体内容如下JSexport default {data() { &n
- 最初打算使用scroll-view实现,效果好、流畅、有惯性滑动,但由于滚动条没法去掉、无法实现上下层的帧布局,最终放弃了。还是自己写个吧,
- 本文介绍了tf.truncated_normal与tf.random_normal的详细用法,分享给大家,具体如下:tf.truncated
- 从一个字符串开始在CODE上查看代码片派生到我的代码片 >>>time_str='2008-08-08
- DECLARE @PAGESIZE INT DECLARE @PAGEINDEX INT DECLARE @PAGECOUNT INT DE
- 1、上下文概念上下文,说白了就是所谓的语境,就是语言环境。比如单独拎出来一篇文章的某一句话,我们可能不能理解它的意思,但是通过这句话所处的语
- 前言学会向程序中添加必要的注释,也是很重要的。注释不仅可以用来解释程序某些部分的作用和功能(用自然语言描述代码的功能),在必要时,还可以将代
- 其实这个东西没什么技术含量,就是给大家提供一个给表格加滚动条的思路。运行代码框<html><head><tit