# docx > 全面的文档创建、编辑和分析,支持跟踪更改、注释、格式保留和文本提取。当 Claude 需要使用专业文档(.docx 文件)时用于:(1)创建新文档,(2)修改或编辑内容,(3)处理跟踪更改,(4)添加注释,或任何其他文档任务 - Author: ZoneCNH - Repository: OpsFlux/skills - Version: 20251230095342 - Stars: 0 - Forks: 0 - Last Updated: 2026-02-06 - Source: https://github.com/OpsFlux/skills - Web: https://mule.run/skillshub/@@OpsFlux/skills~docx:20251230095342 --- --- name: docx description: "全面的文档创建、编辑和分析,支持跟踪更改、注释、格式保留和文本提取。当 Claude 需要使用专业文档(.docx 文件)时用于:(1)创建新文档,(2)修改或编辑内容,(3)处理跟踪更改,(4)添加注释,或任何其他文档任务" license: 专有。LICENSE.txt 包含完整条款 --- # DOCX 创建、编辑和分析 ## 概述 用户可能要求您创建、编辑或分析 .docx 文件的内容。.docx 文件本质上是一个包含 XML 文件和其他资源的 ZIP 存档,您可以读取或编辑这些文件。针对不同的任务,您有不同的工具和工作流程可用。 ## 工作流程决策树 ### 读取/分析内容 使用下面的"文本提取"或"原始 XML 访问"部分 ### 创建新文档 使用"创建新的 Word 文档"工作流程 ### 编辑现有文档 - **您自己的文档 + 简单更改** 使用"基本 OOXML 编辑"工作流程 - **其他人的文档** 使用**"修订工作流程"**(推荐默认) - **法律、学术、商业或政府文档** 使用**"修订工作流程"**(必需) ## 读取和分析内容 ### 文本提取 如果您只需要读取文档的文本内容,应该使用 pandoc 将文档转换为 markdown。Pandoc 提供了对保留文档结构的出色支持,并且可以显示跟踪更改: ```bash # 使用跟踪更改将文档转换为 markdown pandoc --track-changes=all path-to-file.docx -o output.md # 选项:--track-changes=accept/reject/all ``` ### 原始 XML 访问 您需要原始 XML 访问权限来处理:注释、复杂格式、文档结构、嵌入媒体和元数据。对于这些功能中的任何一个,您都需要解包文档并读取其原始 XML 内容。 #### 解包文件 `python ooxml/scripts/unpack.py ` #### 关键文件结构 * `word/document.xml` - 主文档内容 * `word/comments.xml` - 在 document.xml 中引用的注释 * `word/media/` - 嵌入图像和媒体文件 * 跟踪的更改使用 ``(插入)和 ``(删除)标签 ## 创建新的 Word 文档 从头创建新的 Word 文档时,请使用 **docx-js**,它允许您使用 JavaScript/TypeScript 创建 Word 文档。 ### 工作流程 1. **必需 - 阅读整个文件**:从头到尾完整阅读 [`docx-js.md`](docx-js.md)(约 500 行)。**在阅读此文件时永远不要设置任何范围限制。** 阅读完整的文件内容以获取详细的语法、关键格式规则和最佳实践,然后再继续创建文档。 2. 使用 Document、Paragraph、TextRun 组件创建 JavaScript/TypeScript 文件(您可以假设所有依赖项都已安装,但如果没有,请参阅下面的依赖项部分) 3. 使用 Packer.toBuffer() 导出为 .docx ## 编辑现有的 Word 文档 编辑现有的 Word 文档时,请使用 **Document 库**(一个用于 OOXML 操作的 Python 库)。该库自动处理基础设施设置,并提供文档操作方法。对于复杂场景,您可以直接通过库访问底层 DOM。 ### 工作流程 1. **必需 - 阅读整个文件**:从头到尾完整阅读 [`ooxml.md`](ooxml.md)(约 600 行)。**在阅读此文件时永远不要设置任何范围限制。** 阅读完整的文件内容以获取 Document 库 API 和直接编辑文档文件的 XML 模式。 2. 解包文档:`python ooxml/scripts/unpack.py ` 3. 使用 Document 库创建并运行 Python 脚本(参见 ooxml.md 中的"Document 库"部分) 4. 打包最终文档:`python ooxml/scripts/pack.py ` Document 库为常见操作提供高级方法,并为复杂场景提供直接 DOM 访问。 ## 文档审查的修订工作流程 此工作流程允许您在 OOXML 中实现之前使用 markdown 规划全面的跟踪更改。**关键**:对于完整的跟踪更改,您必须系统地实现所有更改。 **批处理策略**:将相关更改分组为 3-10 个更改的批次。这使得调试易于管理,同时保持效率。在进入下一个批次之前测试每个批次。 **原则:最少、精确的编辑** 实现跟踪更改时,只标记实际更改的文本。重复未更改的文本使编辑更难审查,并且看起来不专业。将替换分解为:[未更改的文本] + [删除] + [插入] + [未更改的文本]。通过提取原始的 `` 元素并重用它,为未更改的文本保留原始运行的 RSID。 示例 - 在句子中将"30 天"更改为"60 天": ```python # 错误 - 替换整个句子 '期限为 30 天。期限为 60 天。' # 正确 - 仅标记更改的内容,为未更改的文本保留原始 '期限为 3060 天。' ``` ### 跟踪更改工作流程 1. **获取 markdown 表示**:保留跟踪更改将文档转换为 markdown: ```bash pandoc --track-changes=all path-to-file.docx -o current.md ``` 2. **识别并分组更改**:审查文档并识别所有需要的更改,将其组织为逻辑批次: **定位方法**(用于在 XML 中查找更改): - 章节/标题编号(例如,"第 3.2 节"、"第四条") - 如果编号则为段落标识符 - 带有独特周围文本的 Grep 模式 - 文档结构(例如,"第一段"、"签名块") - **不要使用 markdown 行号**——它们不映射到 XML 结构 **批次组织**(每批分组 3-10 个相关更改): - 按章节:"批次 1:第 2 节修正"、"批次 2:第 5 节更新" - 按类型:"批次 1:日期修正"、"批次 2:当事人名称更改" - 按复杂性:从简单的文本替换开始,然后处理复杂的结构更改 - 按顺序:"批次 1:第 1-3 页"、"批次 2:第 4-6 页" 3. **阅读文档并解包**: - **必需 - 阅读整个文件**:从头到尾完整阅读 [`ooxml.md`](ooxml.md)(约 600 行)。**在阅读此文件时永远不要设置任何范围限制。** 特别注意"Document 库"和"跟踪更改模式"部分。 - **解包文档**:`python ooxml/scripts/unpack.py ` - **注意建议的 RSID**:解包脚本将建议一个 RSID 用于您的跟踪更改。复制此 RSID 以在步骤 4b 中使用。 4. **分批实现更改**:按逻辑(按章节、按类型或按接近程度)对更改进行分组,并在单个脚本中一起实现它们。这种方法: - 使调试更容易(更小的批次 = 更容易隔离错误) - 允许增量进度 - 保持效率(3-10 个更改的批次大小效果很好) **建议的批处理分组**: - 按文档章节(例如,"第 3 节更改"、"定义"、"终止条款") - 按更改类型(例如,"日期更改"、"当事人名称更新"、"法律术语替换") - 按接近程度(例如,"第 1-3 页的更改"、"文档上半部分的更改") 对于每批相关更改: **a. 将文本映射到 XML**:在 `word/document.xml` 中 Grep 文本以验证文本如何跨 `` 元素分割。 **b. 创建并运行脚本**:使用 `get_node` 查找节点,实现更改,然后 `doc.save()`。参见 ooxml.md 中的**"Document 库"**部分以获取模式。 **注意**:始终在编写脚本之前立即 grep `word/document.xml` 以获取当前行号并验证文本内容。每次脚本运行后行号都会更改。 5. **打包文档**:所有批次完成后,将解包目录转换回 .docx: ```bash python ooxml/scripts/pack.py unpacked reviewed-document.docx ``` 6. **最终验证**:对完整文档进行全面检查: - 将最终文档转换为 markdown: ```bash pandoc --track-changes=all reviewed-document.docx -o verification.md ``` - 验证所有更改都正确应用: ```bash grep "原始短语" verification.md # 应该找不到 grep "替换短语" verification.md # 应该找到 ``` - 检查是否引入了任何意外的更改 ## 将文档转换为图像 要视觉分析 Word 文档,请使用两步过程将它们转换为图像: 1. **将 DOCX 转换为 PDF**: ```bash soffice --headless --convert-to pdf document.docx ``` 2. **将 PDF 页面转换为 JPEG 图像**: ```bash pdftoppm -jpeg -r 150 document.pdf page ``` 这将创建 `page-1.jpg`、`page-2.jpg` 等文件。 选项: - `-r 150`:将分辨率设置为 150 DPI(调整质量/大小平衡) - `-jpeg`:输出 JPEG 格式(如果首选 PNG,则使用 `-png`) - `-f N`:要转换的第一页(例如,`-f 2` 从第 2 页开始) - `-l N`:要转换的最后一页(例如,`-l 5` 在第 5 页停止) - `page`:输出文件的前缀 特定范围的示例: ```bash pdftoppm -jpeg -r 150 -f 2 -l 5 document.pdf page # 仅转换第 2-5 页 ``` ## 代码样式指南 **重要**:为 DOCX 操作生成代码时: - 编写简洁的代码 - 避免冗长的变量名和冗余操作 - 避免不必要的打印语句 ## 依赖项 必需的依赖项(如果不可用则安装): - **pandoc**:`sudo apt-get install pandoc`(用于文本提取) - **docx**:`npm install -g docx`(用于创建新文档) - **LibreOffice**:`sudo apt-get install libreoffice`(用于 PDF 转换) - **Poppler**:`sudo apt-get install poppler-utils`(用于 pdftoppm 将 PDF 转换为图像) - **defusedxml**:`pip install defusedxml`(用于安全 XML 解析)