
libre office mcp
一个让 AI 助手与 LibreOffice 文档交互的 Model Context Protocol (MCP) 服务器。
Repository Info
About This Server
一个让 AI 助手与 LibreOffice 文档交互的 Model Context Protocol (MCP) 服务器。
Model Context Protocol (MCP) - This server can be integrated with AI applications to provide additional context and capabilities, enabling enhanced AI interactions and functionality.
Documentation
LibreOffice MCP Server
A Model Context Protocol (MCP) server that enables Claude and other AI assistants to interact with LibreOffice documents directly.
Overview
This MCP server provides a bridge between AI assistants like Claude and LibreOffice, allowing the AI to create, read, edit, and format LibreOffice documents. Built on the Model Context Protocol, it exposes LibreOffice functionality as tools that can be called by compatible AI applications.
Features
LibreOffice Suite Support
- LibreWriter
- Implemented:
-
Create new documents
-
Open and read text documents
-
Copy documents
-
List documents in a directory
-
Get document properties and metadata
-
Add text to documents
-
Add headings with different levels
-
Add formatted paragraphs
-
Add tables with data
-
Format tables with borders, colors, and header rows
-
Search and replace text
-
Delete specific text
-
Delete paragraphs
-
Insert page breaks (partial implementation)
-
Insert images
-
Format specific text (bold, italic, color, size)
-
- Implemented:
- LibreCalc
- LibreImpress
Installation
Requirements
- Python 3.10 or higher
- LibreOffice installed
- Claude for Desktop (or another MCP-compatible client)
Setup Instructions
-
Clone the repository
git clone https://github.com/harshithb3304/libre-office-mcp.git cd libre-office-mcp/libre-writer -
Set up Python environment
UV Installation #For Windows powershell -ExecutionPolicy ByPass -c "irm https://astral.sh/uv/install.ps1 | iex" #For MacOS/Linux curl -LsSf https://astral.sh/uv/install.sh | sh # With uv (recommended) uv init uv venv uv add mcp[cli] httpx # With pip pip install "mcp[cli]" httpx -
Install LibreOffice
- Windows: Download from LibreOffice website
- macOS:
brew install --cask libreoffice
Usage with Claude for Desktop
-
Configure Claude for Desktop
Add the following to your Claude for Desktop configuration file:
- Windows:
%APPDATA%\Claude\claude_desktop_config.json - macOS:
~/Library/Application Support/Claude/claude_desktop_config.json
{ "mcpServers": { "libreoffice-server": { "command": "uv", "args": [ "--directory", "C:\\path\\to\\libreoffice-mcp-server", "run", "main.py" ] } } }or
{ "mcpServers": { "libreoffice-server": { "command": "python", "args": [ "C:\\path\\to\\the\\main.py" ] } } }⚠️ Note: Replace
C:\\path\\to\\libreoffice-mcp-serverwith the actual path to where you cloned the repository. - Windows:
-
Restart Claude for Desktop
-
Interact with LibreOffice
You can now ask Claude to perform actions like:
- "Create a new document with a title and three paragraphs"
- "List all the documents in my Documents folder"
- "Open my report.odt file and add a table with 4 columns and 5 rows"
!Claude LibreOffice Interaction
How It Works
The server consists of three main components:
-
LibreOffice Helper (
helper.py): A Python script that communicates directly with LibreOffice using the UNO bridge API. -
MCP Server (
libre.py): The main MCP server that exposes LibreOffice functionality as tools for AI assistants. -
Launcher (
main.py): A script that launches both the helper and the MCP server.
When a request comes in from Claude:
- The MCP server receives the request
- It forwards the command to the LibreOffice helper via a socket connection
- The helper executes the command using LibreOffice's UNO API
- The result is sent back to the MCP server and then to Claude
Configuration Options
The server will use your Documents folder as the default location for creating new documents if no path is specified. You can change this by modifying the get_default_document_path function in libre.py.
Troubleshooting
Common Issues
-
"LibreOffice helper is not running"
Make sure LibreOffice is installed and the path to the LibreOffice Python executable is correct inmain.py. -
"Connection refused"
The helper script may not have started correctly. Check if port 8765 is already in use. -
"Failed to connect to LibreOffice desktop"
LibreOffice may not be running in headless mode. Check if port 2002 is available.
Contributing
Contributions are welcome! Here are some areas that need improvement:
- Fixing image insertion functionality
- Implementing robust text formatting
- Supporting additional LibreOffice features
- Improving error handling
Quick Start
Clone the repository
git clone https://github.com/harshithb3304/libre-office-mcpInstall dependencies
cd libre-office-mcp
npm installFollow the documentation
Check the repository's README.md file for specific installation and usage instructions.
Repository Details
Recommended MCP Servers
Discord MCP
Enable AI assistants to seamlessly interact with Discord servers, channels, and messages.
Knit MCP
Connect AI agents to 200+ SaaS applications and automate workflows.
Apify MCP Server
Deploy and interact with Apify actors for web scraping and data extraction.
BrowserStack MCP
BrowserStack MCP Server for automated testing across multiple browsers.
Zapier MCP
A Zapier server that provides automation capabilities for various apps.