你的代码中存在一个小错误,就是在删除段落时,没有正确获取要删除的段落。下面是修正后的代码:
- from docx import Document
- def delete_paragraphs(docx, start_index, end_index):
- paragraphs = docx.paragraphs[start_index-1:end_index] # 获取要删除的段落
- for p in paragraphs:
- p._element.getparent().remove(p._element) # 删除段落的XML元素
- docx = Document('111.docx')
- delete_paragraphs(docx, 2, 3) # 删除第2到第3个段落
- docx.save('111.docx')
复制代码
修复的说明:
- 首先,我们用`docx.paragraphs[start_index-1:end_index]`获取要删除的段落列表。注意,Python列表的索引是从0开始的,而你的索引是从1开始的,所以需要减去1。
- 然后,我们遍历要删除的段落列表,使用`p._element.getparent().remove(p._element)`删除段落的XML元素。
这样,你的代码就能正常删除指定的段落了。希望对你有帮助!
以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。