mcp-server-spreadsheet
mcp-name: io.github.marekrost/mcp-server-spreadsheet
Data-first MCP server for reading and writing spreadsheet files (.xlsx, .csv, .ods).
Key features
Multi-format — works with Excel (
.xlsx), CSV (.csv), and OpenDocument (.ods) files through a unified tool interface.Dual mode — cell-level workbook operations and a DuckDB-powered SQL query engine, interleaved freely on the same file.
Workbook essentials — worksheets, rows, columns, cells, search.
Data-only — preserves existing formatting but only reads and writes values.
Stateless — every call specifies
fileandsheetexplicitly; no handles or sessions.Atomic saves — writes go to a temp file, then
os.replace()into the target path.Type coercion on write — numeric strings become numbers, everything else is text.
SQL across sheets — JOINs, GROUP BY, aggregates, subqueries via in-memory DuckDB; mutations write back to the file.
CSV as single-sheet workbook — CSV files are treated as a workbook with one sheet named
default.
Requirements
Python 3.13+
Installation
From PyPI (recommended)
No local checkout needed — just configure your MCP client (see below).
From source (for development)
git clone https://github.com/marekrost/mcp-server-spreadsheet.git
cd mcp-server-spreadsheet
uv syncUsage
Claude Desktop
Add to your claude_desktop_config.json:
Using PyPI (recommended):
{
"mcpServers": {
"mcp-server-spreadsheet": {
"command": "uvx",
"args": ["mcp-server-spreadsheet"]
}
}
}Using local source:
{
"mcpServers": {
"mcp-server-spreadsheet": {
"command": "uv",
"args": ["run", "--directory", "/path/to/mcp-server-spreadsheet", "main.py"]
}
}
}Claude Code
Add to your .mcp.json:
Using PyPI (recommended):
{
"mcpServers": {
"mcp-server-spreadsheet": {
"command": "uvx",
"args": ["mcp-server-spreadsheet"]
}
}
}Using local source:
{
"mcpServers": {
"mcp-server-spreadsheet": {
"command": "uv",
"args": ["run", "--directory", "/path/to/mcp-server-spreadsheet", "main.py"]
}
}
}Standalone (stdio transport)
# PyPI
uvx mcp-server-spreadsheet
# Local source
uv run main.pyFormat notes
Format | Sheets | Formulas | Types |
| Multiple | Preserved as strings | Native (int, float, date, bool) |
| Multiple | Not preserved | Native (int, float, date, bool) |
| Single ( | N/A | Inferred on load (int, float, text) |
Sheet management tools (add_sheet, delete_sheet, copy_sheet) raise an error for CSV files.
Tools
Workbook Operations
Tool | Description |
| List all spreadsheet files in a directory (non-recursive) |
| Create a new empty spreadsheet file (format by extension) |
| Copy an existing file to a new path |
Sheet Operations
Tool | Description |
| List all sheet names in a workbook |
| Add a new sheet (optional name and position) |
| Rename an existing sheet |
| Delete a sheet by name |
| Duplicate a sheet within a workbook (optional new name and position) |
Reading Data
Tool | Description |
| Read entire sheet as rows (optional row/column bounds) |
| Read a single cell value, e.g. |
| Read a rectangular range, e.g. |
| Get row and column count of the used range |
Writing Data
Tool | Description |
| Write a value to a single cell |
| Write a 2D array starting at a given cell |
| Append rows after the last used row |
| Insert blank or pre-filled rows at a position (shifts rows down) |
| Delete rows by index (shifts rows up) |
| Clear values in a range without removing rows/columns |
| Copy a block of cells to another location (optionally to a different sheet) |
Column Operations
Tool | Description |
| Insert blank columns at a position |
| Delete columns by index |
Search
Tool | Description |
| Search for a value or regex pattern, returns matching cell references |
Table Mode (SQL)
Tool | Description |
| Inspect column names, inferred types, row count, and sample values |
| Execute a read-only SQL |
| Execute |
SQL examples:
-- Filter and sort
SELECT name, revenue FROM Sales WHERE status = 'Active' ORDER BY revenue DESC LIMIT 20
-- Cross-sheet JOIN
SELECT o.order_id, c.name FROM Orders o JOIN Customers c ON o.customer_id = c.id
-- Aggregate
SELECT department, COUNT(*) AS n, AVG(salary) AS avg FROM Employees GROUP BY department
-- Mutate
UPDATE Sales SET status = 'Closed' WHERE quarter = 'Q1' AND revenue < 1000
DELETE FROM Logs WHERE date < '2024-01-01'Sheet names with spaces must be quoted: SELECT * FROM "Q1 Sales".
Common Parameters
Every sheet-level tool accepts:
Parameter | Required | Description |
| yes | Path to the spreadsheet file (.xlsx, .csv, or .ods) |
| no | Sheet name. Defaults to the first sheet in the workbook |
All row/column indices are 1-based. Cell references use A1 notation (A1, $B$2).