Python實現(xiàn)批量生成,重命名和刪除word文件
批量生成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文檔的相關(guān)操作使用docx模塊;
批量新建文件名
場景:需要新建多個類似文件名
比如:今天的事例是新建12個文件名為:
保安員考試試卷1及答案.docx
保安員考試試卷2及答案.docx
? ...
保安員考試試卷12及答案.docx
痛點:
手動操作重復性高,出錯率高,易造成人疲勞,降低效率;
def gen_names(pre_fix, num):
"""
批量生成文件名
:param pre_fix: 文件名的前綴
:param num: 文件數(shù)量
:return:name_list :文件名列表(所有要生成的文件名)
"""
print("生成文件名列表開始")
name_list = []
for i in range(1, num + 1):
tmp = pre_fix + str(i)
name_list.append(tmp)
print("生成文件名列表結(jié)束")
return name_list
生成word文件
生成單個文件
def new_one_file(document, name):
"""
生成單個文件
:param document:
:param name: 文件名
:return:
"""
print("單個生成文件開始")
document.save(name + '.docx')
print("單個生成文件結(jié)束")
生成多個文件
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("批量生成文件結(jié)束")
重命名文件
def rename_file(path):
"""
將path路徑下的文件都重命名
規(guī)則:在原文件名后面加上 ---> "及答案." 字段
: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("重命名結(jié)束")
刪除文件
def del_files(path):
"""
刪除指定路徑下的文件
:param path:
:return:
"""
print("刪除開始")
files = os.listdir(path)
for file in files:
os.remove(os.path.join(path, file))
print("刪除成功")
函數(shù)調(diào)用
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: 文件數(shù)量
:return:name_list :文件名列表(所有要生成的文件名)
"""
print("生成文件名列表開始")
name_list = []
for i in range(1, num + 1):
tmp = pre_fix + str(i)
name_list.append(tmp)
print("生成文件名列表結(jié)束")
return name_list
def new_one_file(document, name):
"""
生成單個文件
:param document:
:param name: 文件名
:return:
"""
print("單個生成文件開始")
document.save(name + '.docx')
print("單個生成文件結(jié)束")
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("批量生成文件結(jié)束")
def rename_file(path):
"""
將path路徑下的文件都重命名
規(guī)則:在原文件名后面加上 ---> "及答案." 字段
: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("重命名結(jié)束")
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)
#創(chuàng)建多個文件
# new_many_file(document, name_all)
# 重命名文件
# rename_file("tmp")
# 刪除文件
del_files("tmp")以上就是Python實現(xiàn)批量生成,重命名和刪除word文件的詳細內(nèi)容,更多關(guān)于Python word的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
windows端python版本管理工具pyenv-win安裝使用
這篇文章主要介紹了如何通過git方式下載和配置pyenv-win,包括下載、克隆倉庫、配置環(huán)境變量等步驟,同時還詳細介紹了如何使用pyenv-win管理Python版本,需要的朋友可以參考下2025-01-01
基于python實現(xiàn)cdn日志文件導入mysql進行分析
這篇文章主要介紹了基于python實現(xiàn)cdn日志文件導入mysql進行分析,本文以阿里云CDN日志作為輔助查詢數(shù)據(jù)展開主題內(nèi)容,其它云平臺大同小異,需要的小伙伴可以參考一下2022-05-05
Python中創(chuàng)建相關(guān)系數(shù)矩陣的方法小結(jié)
相關(guān)系數(shù)矩陣是一種用于衡量變量之間關(guān)系的重要工具,本文將介紹在 Python 中創(chuàng)建相關(guān)系數(shù)矩陣的不同方法,感興趣的小伙伴可以跟隨小編一起學習一下2023-12-12
從DataFrame中提取出Series或DataFrame對象的方法
今天小編就為大家分享一篇從DataFrame中提取出Series或DataFrame對象的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-11-11

