import os from openpyxl import load_workbook import docx # 读取Excel文件 workbook = load_workbook(filename=r'D:\好记薪\工商资料生成\表格.xlsx') sheet = workbook['需调用文档'] # 判断C列是否为空 if sheet['C2'].value: # 合并A、B文档 merge_docx(['A.docx', 'B.docx'], 'AB.docx') if sheet['C3'].value or sheet['C4'].value or sheet['C5'].value or sheet['C6'].value: # 合并A、B、C文档 merge_docx(['A.docx', 'B.docx', 'C.docx'], 'ABC.docx') if sheet['C7'].value: # 合并A、B、C、D文档 merge_docx(['A.docx', 'B.docx', 'C.docx', 'D.docx'], 'ABCD.docx') if sheet['C8'].value: # 合并A、B、C、E文档 merge_docx(['A.docx', 'B.docx', 'C.docx', 'E.docx'], 'ABCE.docx') # 合并docx文件 def merge_docx(file_list, merged_file_name): # 如果合并后的文件已存在,则直接返回 if os.path.exists(merged_file_name): return # 创建合并后的文档对象 merged_doc = docx.Document() # 合并文件内容 for file_name in file_list: doc = docx.Document(file_name) for para in doc.paragraphs: merged_doc.add_paragraph(para.text) for table in doc.tables: merged_doc.add_table(table.rows, table.columns) # 保存合并后的文档 merged_doc.save(merged_file_name),报错:NameError: name 'merge_docx' is not defined
时间: 2024-03-22 08:39:49 浏览: 579
你的代码中调用了`merge_docx`函数,但是在调用之前并没有定义该函数,因此导致了`NameError: name 'merge_docx' is not defined`错误。
为了解决这个问题,你应该把`merge_docx`函数定义提到调用的前面,或者把它定义在另一个文件中并且在当前文件中导入。如下所示:
```
import os
from openpyxl import load_workbook
import docx
# 合并docx文件
def merge_docx(file_list, merged_file_name):
# 如果合并后的文件已存在,则直接返回
if os.path.exists(merged_file_name):
return
# 创建合并后的文档对象
merged_doc = docx.Document()
# 合并文件内容
for file_name in file_list:
doc = docx.Document(file_name)
for para in doc.paragraphs:
merged_doc.add_paragraph(para.text)
for table in doc.tables:
merged_doc.add_table(table.rows, table.columns)
# 保存合并后的文档
merged_doc.save(merged_file_name)
# 读取Excel文件
workbook = load_workbook(filename=r'D:\好记薪\工商资料生成\表格.xlsx')
sheet = workbook['需调用文档']
# 判断C列是否为空
if sheet['C2'].value:
# 合并A、B文档
merge_docx(['A.docx', 'B.docx'], 'AB.docx')
if sheet['C3'].value or sheet['C4'].value or sheet['C5'].value or sheet['C6'].value:
# 合并A、B、C文档
merge_docx(['A.docx', 'B.docx', 'C.docx'], 'ABC.docx')
if sheet['C7'].value:
# 合并A、B、C、D文档
merge_docx(['A.docx', 'B.docx', 'C.docx', 'D.docx'], 'ABCD.docx')
if sheet['C8'].value:
# 合并A、B、C、E文档
merge_docx(['A.docx', 'B.docx', 'C.docx', 'E.docx'], 'ABCE.docx')
```
这样就可以避免`NameError: name 'merge_docx' is not defined`错误。
阅读全文