ironcalc-mcp
Enables AI agents to directly create, read, edit, and save Excel (.xlsx) spreadsheets using natural language through the Model Context Protocol, supporting cells, sheets, formatting, and formulas without writing Python code.
README
ironcalc-mcp
MCP server for the IronCalc spreadsheet engine. Create, read, edit, and save xlsx files through the Model Context Protocol.
Covers the full surface of the IronCalc Python SDK - everything you can do with ironcalc in Python, you can do through MCP.
Motivation
I was really inspired by paper.design's real-time MCP workflow, where exposing a design tool via MCP enables custom, extensible agent workflows that feel native rather than bolted on.
Current AI-spreadsheet integrations (like Claude's cowork mode for Excel) add an unnecessary layer of abstraction - the agent writes Python code that manipulates Excel, instead of talking to the spreadsheet directly. This MCP server removes that indirection. Agents read cells, write formulas, and get evaluated results in one hop. No codegen middleman, no openpyxl glue scripts.
Huge thanks to the IronCalc contributors - their Python SDK API is so clean that this entire MCP server is basically thin wrappers. The hard work is all theirs.
Current limitation: the server works with an in-memory workbook - load a file, edit it, save it back. There's no real-time streaming to a running IronCalc UI yet. The engine already has a diff queue for syncing, so the plumbing is there. If IronCalc adds a WebSocket bridge to their web app, we can wire up live sync and get a true reactive workflow - agent edits appearing in the browser as they happen.
Quick start
uvx ironcalc-mcp
Claude Code
claude mcp add ironcalc -- uvx ironcalc-mcp
Claude Desktop / Cursor
Add to your MCP config:
{
"mcpServers": {
"ironcalc": {
"command": "uvx",
"args": ["ironcalc-mcp"]
}
}
}
Examples
Build a spreadsheet from scratch
Create a budget with formulas and save it
Audit an existing xlsx for errors
Load quarterly_report.xlsx and find all #NAME?, #REF!, #VALUE! errors. Tell me which formulas are broken and why.
Fix broken cross-sheet references
The P&L sheet was renamed but formulas in the DCF sheet still reference the old name. Find and fix all broken references.
Build a financial model
Create a 5-year DCF model with revenue assumptions in one sheet, P&L in another, and free cash flow calculation in a third. Use =NPV() and =IRR() for valuation.
Analyze and transform data
Load sales_data.xlsx, add a column with running totals, insert a summary row at the bottom, and save.
Available tools (21)
Workbook
| Tool | Description |
|---|---|
create_workbook |
Create a new empty workbook. Params: name, locale, timezone, language |
load_workbook |
Load workbook from an xlsx file. Params: file_path, locale, timezone, language |
save_workbook |
Save workbook to xlsx. Params: file_path (optional, defaults to load path) |
get_workbook_info |
Get sheets list, dimensions, state, colors |
Cells
| Tool | Description |
|---|---|
get_cell |
Get content, formatted value, and type of a single cell |
get_cells |
Read a rectangular range of cells |
set_cell |
Set a cell's value or formula (prefix with =) |
set_cells |
Batch set multiple cells in one call |
Sheets
| Tool | Description |
|---|---|
add_sheet |
Create a new sheet (auto-named or custom name) |
delete_sheet |
Remove a sheet by index |
rename_sheet |
Rename a sheet |
set_sheet_color |
Set the tab color (hex) |
Structure
| Tool | Description |
|---|---|
insert_rows |
Insert rows at a position |
delete_rows |
Delete rows at a position |
insert_columns |
Insert columns at a position |
delete_columns |
Delete columns at a position |
set_column_width |
Set column width in points |
set_row_height |
Set row height in points |
set_frozen_rows |
Freeze top N rows |
set_frozen_columns |
Freeze left N columns |
Formatting
| Tool | Description |
|---|---|
get_cell_style |
Get font, fill, border, alignment, number format |
set_cell_styleis not yet available — the IronCalc Python binding exposes style properties as read-only. PRs welcome to add#[pyo3(get, set)]upstream.
Contributing
Contributions are welcome! To get started:
git clone https://github.com/yolonir/ironcalc-mcp
cd ironcalc-mcp
uv sync
uv run ironcalc-mcp
Please create a new branch for your changes and open a pull request against main. Pls keep them focused.
License
MIT
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.