SKILLful MCP Docx Processor
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@SKILLful MCP Docx ProcessorCreate a document called sample.docx and add a heading 'Introduction'."
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
SKILLful MCP Docx Processor
A Word document processing service based on FastMCP and python-docx, exposing a single gateway tool (docx_process) that routes to 63 operations, covering the full document lifecycle: creation, editing, formatting, and querying.
Designed for seamless integration with Claude Code via the MCP protocol and Claude's skill system.
Features
Document Management (7)
Create, open, save, save-as, copy, close, and reload documents. Includes lock file detection and save retry logic.
Content Addition (8)
Add paragraphs, headings (1-9), tables, list items (bulleted/numbered with 0-8 indent levels), images, page breaks, sections, and table of contents.
Content Editing (8)
Search text across paragraphs and tables, search-and-replace with preview mode, replace sections by heading, edit by keyword, delete paragraphs/text, and edit table cells.
Table Operations (8)
Add/delete rows and columns, merge/split cells, set table borders and cell shading.
Formatting (19)
Page margins, orientation, size, headers/footers, columns, page numbers, line spacing, paragraph spacing/indent, paragraph borders/shading, text highlight/strikethrough/superscript/subscript, text direction (LTR/RTL), tab stops, hyperlinks, and cell formatting.
Style Management (3)
Create, modify, and list document styles (paragraph, character, table, list).
Annotations & References (4)
Add bookmarks, comments, footnotes, and endnotes.
Query (4)
Get document metadata, paragraph details with format JSON, table cell content, and page layout info.
Requirements
Python >= 3.10
uv package manager
Installation
# Clone the repository
git clone https://github.com/Zeke-777/SKILLful-mcp-docx-processor.git
cd SKILLful-mcp-docx-processor
# Install dependencies
uv syncConfigure MCP Server
MCP server configuration supports two levels:
Project-level Configuration
Add the following to the target project's .claude/settings.local.json (takes effect for the current project only):
{
"mcpServers": {
"docx-processor": {
"command": "uv",
"args": [
"run",
"--directory",
"/path/to/SKILLful-mcp-docx-processor",
"python",
"server.py"
]
}
}
}Global Configuration
Add the following to ~/.claude/settings.json (takes effect for all projects):
{
"mcpServers": {
"docx-processor": {
"command": "uv",
"args": [
"run",
"--directory",
"/path/to/SKILLful-mcp-docx-processor",
"python",
"server.py"
]
}
}
}Replace
/path/to/SKILLful-mcp-docx-processorwith the actual path to this project.
Install Skill
Skill files support both project-level and global installation. Choose one as needed.
Project-level Installation
Takes effect for the current project only. Skill files reside within the project directory:
# Run in your target project's root directory
mkdir -p .claude/skills
# Copy Skill files to the target project
cp -r /path/to/SKILLful-mcp-docx-processor/skills/docx-process .claude/skills/Global Installation
Takes effect for all projects. Skill files reside in the user's home directory:
# Copy Skill files to the global directory
mkdir -p ~/.claude/skills
cp -r /path/to/SKILLful-mcp-docx-processor/skills/docx-process ~/.claude/skills/After installation, the directory structure is as follows:
.claude/ # Project-level or ~/.claude/ # Global
└── skills/
└── docx-process/
├── SKILL.md # Route table
└── references/
├── doc-management.md # Document management
├── content-operations.md # Content operations
├── table-operations.md # Table operations
├── formatting.md # Formatting
└── annotations-query.md # Annotations & queriesClaude Code automatically loads SKILL.md before calling docx_process, ensuring every call has the complete route and parameter reference.
Usage
Once configured, the docx_process tool becomes available in Claude Code. The tool uses a single gateway pattern:
docx_process(route="create_document", params={"file_path": "output.docx"})
docx_process(route="add_heading", params={"text": "Hello World", "level": 1})
docx_process(route="save_document", params={})The built-in docx-process skill automatically loads the route table and parameter specifications before each call, ensuring correct usage.
Architecture
server.py -- MCP server with all handler logic (2,247 lines)
SKILL.md -- Route table (loaded on every call)
references/*.md -- 5 category reference docs (loaded on demand)The server exposes one tool (docx_process) that dispatches to handler functions via a ROUTE_HANDLERS dictionary.
Context Efficiency
If all 63 routes were written into the tool's docstring or loaded at once, it would consume a large portion of the context window. This project uses on-demand Skill loading to significantly reduce context overhead:
Loading Stage | Content | Lines |
Tool schema | Docstring (parameter specs only) | 6 |
Every call | SKILL.md route table | 116 |
On demand | Single reference file | 47-177 |
Total per call | 169-299 |
Compared to a naive approach (docstring with full route list ~30 lines + full SKILL.md 595 lines = ~625 lines), context usage is reduced by 52-73%.
This means:
More room for actual tasks — saved context can be used for document content and business logic
Faster responses — fewer tokens means faster inference
Lower costs — significantly fewer tokens consumed per call
Robustness
File lock detection for all file operations
Parameter validation across all routes (levels, rows/cols, colors, spacing, etc.)
State management with overwrite warnings and cleanup on close
Unified error handling with clear, actionable messages
Save retry (3 attempts, 2s intervals) for locked files
Known Limitations
Single-document model (opening a new document warns about closing the current one)
No per-run rich text within a paragraph (whole-paragraph formatting only)
No text box support
No concurrent multi-user protection (designed for single-user MCP scenarios)
Acknowledgments
This project is built upon an extension of MCP-Doc, retaining its core DocxProcessor class architecture and 21 foundational document operations. It has been expanded to 63 routes with additional features including file lock detection and on-demand Skill loading. Thanks to the original author for the excellent work.
License
MIT
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Tools
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/Zeke-777/SKILLful-mcp-docx-processor'
If you have feedback or need assistance with the MCP directory API, please join our Discord server