Edit .docx files with tracked changes, comments, and revision restoration — for humans and AI agents
Project description
revisedoc
Edit .docx files the way Word intended — with full change tracking, inline
comments, and revision history. No more sending around unmarked copies or
losing track of what changed. Use it from the command line, from your Python
code, or hook it up as an MCP server so your AI coding agent can edit documents
with the same care a human reviewer would.
Features
- Tracked-changes replace — Replace text using Word-compatible
<w:del>/<w:ins>markup - Inline comments — Anchor comments to any text range
- Revision inspection — List all tracked changes with id, author, date, type, text
- Revision restoration — Undo a specific tracked change
- MCP server — Expose all operations as structured tools for AI agents (opencode, Claude Code, etc.)
Use Cases
-
Contract redlining — Replace outdated terms in a
.docxcontract with tracked changes so the other side sees exactly what was modified. -
Document review workflows — Annotate drafts with inline comments, then list and restore revisions to review changes systematically.
-
AI-assisted editing — Connect the MCP server to opencode or Claude Code and have your agent propose edits with full change tracking — no more "just trust me, I made some changes."
-
Batch processing — Script document updates across hundreds of files using the Python API, with every change recorded in Word's revision log.
Installation
pip install revisedoc # with pip
pipx install revisedoc # with pipx (isolated)
For AI agent integration (opencode, Claude Code):
pip install "revisedoc[mcp]" # pip — quotes required in zsh
pipx install "revisedoc[mcp]" # pipx — quotes required in zsh
[mcp]is an optional extra — it installs the samerevisedocpackage plus themcpSDK dependency. Without it, the CLI and Python API work fine; only therevisedoc-mcpserver is unavailable.Note for zsh users: the square brackets must be quoted. Use
pip install "revisedoc[mcp]"notpip install revisedoc[mcp].
CLI Usage
# Replace text with tracked changes
revisedoc replace input.docx output.docx "old text" "new text" --author "Me"
# Add a comment
revisedoc comment input.docx output.docx "target text" "my comment" --author "Reviewer"
# List tracked changes
revisedoc list-revisions input.docx
revisedoc list-revisions input.docx --format json
# Undo a revision (restore deleted text)
revisedoc restore input.docx output.docx --revision-id 3
# Undo an insertion instead
revisedoc restore input.docx output.docx --revision-id 3 --restore-type insertion
# Print document plain text
revisedoc get-text input.docx
Python API
from docx import Document
from revisedoc import replace_text, add_comment, list_revisions, restore_revision, get_full_text, finalize_comments
doc = Document("input.docx")
replace_text(doc, "old phrase", "new phrase", author="MyBot")
add_comment(doc, "some specific text", "Review this part", author="Reviewer")
pending = doc.part._pending_comments
doc.save("output.docx")
finalize_comments("output.docx", pending_comments=pending)
MCP Server — AI Agent Integration
Start the MCP server:
revisedoc-mcp
opencode
Add to opencode.json:
{
"mcp": {
"revisedoc": {
"type": "local",
"command": ["revisedoc-mcp"],
"enabled": true
}
}
}
Claude Code
Add to .claude/settings.json:
{
"mcpServers": {
"revisedoc": {
"command": "revisedoc-mcp"
}
}
}
Available Tools
| Tool | Description |
|---|---|
docx_replace |
Replace text with tracked changes |
docx_comment |
Add a comment anchored to text |
docx_list_revisions |
List all tracked changes |
docx_restore |
Undo a revision by ID |
docx_get_text |
Print document plain text |
Development
pip install -e ".[mcp,test]"
pytest tests/ -v
Architecture
The package structure:
src/revisedoc/
├── __init__.py # Public API exports
├── editor.py # Core editing operations
├── cli.py # Command-line interface
└── mcp.py # MCP server for AI agents
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file revisedoc-0.1.1.tar.gz.
File metadata
- Download URL: revisedoc-0.1.1.tar.gz
- Upload date:
- Size: 14.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.14.4
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
e7fa1ad9247cbbb624cb44bc3a0daebd0d136ae4bc0d2d8b7bfec557c47554e5
|
|
| MD5 |
0dec3152c7c9fb6a51767e4489f5f922
|
|
| BLAKE2b-256 |
d180fccf0fba883700f45c54e73904e07ff580fc8848709390630f2bc8a26e3e
|
File details
Details for the file revisedoc-0.1.1-py3-none-any.whl.
File metadata
- Download URL: revisedoc-0.1.1-py3-none-any.whl
- Upload date:
- Size: 10.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.14.4
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
5b2e56647597ff79907ba2d6f43ea27070758298e9525753917b4ddc83135036
|
|
| MD5 |
b3238600b76025cd5c8e822e9d6f117b
|
|
| BLAKE2b-256 |
c7493b7b83ea567d17734724f484b87883ed66cd286bb2ff37fedffa174c324d
|