fcp-sheets
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., "@fcp-sheetsCreate a PE portfolio review workbook with audit checks."
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.
fcp-sheets
MCP server for semantic spreadsheet operations.
What It Does
fcp-sheets lets LLMs create and edit Excel workbooks by describing spreadsheet intent -- data entry, formulas, styling, charts, conditional formatting -- and renders it into standard .xlsx files. Instead of writing openpyxl code cell-by-cell, the LLM works with operations like data A5 block entry, style A1:F1 bold fill:#1a1a2e, and chart add stacked-column data:B3:C7. Built on the FCP framework, powered by openpyxl for serialization.
Quick Example
sheets_session('new "Q4 Report" sheets:"Summary,Details"')
sheets([
'data A1',
'| Region | Q4 Revenue | Q4 Costs | Margin |',
'| North | 1250000 | 875000 | =C2/B2 |',
'| South | 980000 | 710000 | =C3/B3 |',
'| East | 1100000 | 790000 | =C4/B4 |',
'| West | 870000 | 620000 | =C5/B5 |',
'data end',
'style A1:D1 bold fill:#2F5496 color:#FFFFFF',
'style B2:C5 fmt:$#,##0',
'style D2:D5 fmt:0.0%',
'chart add clustered-column title:"Q4 Revenue by Region" data:B1:C5 categories:A2:A5',
])
sheets_session('save as:./q4_report.xlsx')Available MCP Tools
Tool | Purpose |
| Batch mutations -- data entry, formulas, styling, charts, merges, borders |
| Inspect the workbook -- list sheets, describe ranges, read values, find |
| Lifecycle -- new, open, save, checkpoint, undo, redo |
| Full reference card |
Benchmark
In a head-to-head against raw openpyxl on a 6-sheet PE portfolio workbook (84 audit checks):
Metric | FCP | Raw openpyxl | Delta |
Audit Score | 84/84 (100%) | 84/84 (100%) | Tie |
Total Time | 559s (9.3 min) | 1,360s (22.7 min) | FCP 2.4x faster |
Total Cost | $3.37 | $4.11 | FCP 18% cheaper |
Output Tokens | 29,065 | 101,909 | FCP 3.5x fewer |
See docs/benchmark/ for the full writeup, audit script, and output files.
Installation
Requires Python >= 3.11.
pip install fcp-sheetsMCP Client Configuration
{
"mcpServers": {
"sheets": {
"command": "uv",
"args": ["run", "python", "-m", "fcp_sheets"]
}
}
}Architecture
3-layer architecture:
MCP Server (Intent Layer)
Parses op strings, dispatches to verb handlers
|
Semantic Model
Thin wrapper around openpyxl Workbook
Cell ref parser, sheet index, block mode, undo/redo via byte snapshots
|
Serialization (openpyxl)
Semantic model -> .xlsx binary outputKey features:
Block data entry --
data/data endblocks enter tabular data with markdown table syntaxFormulas -- Including cross-sheet references (
='Sheet 2'!B5)Styling -- Font, fill, borders, number formats, merges, alignment
Charts -- Bar, line, pie, scatter, bubble, area, doughnut, stacked variants
Conditional formatting -- Cell-is rules, color scales, data bars
Named ranges & validation -- Drop-down lists, range names
Page setup -- Orientation, print titles, frozen panes, filters
Undo/redo -- Full workbook snapshots with event sourcing
Development
uv sync
uv run pytest # 616 tests
uv run ruff check # linting
uv run pyright # type checkingLicense
MIT
This server cannot be installed
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
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/os-tack/fcp-sheets'
If you have feedback or need assistance with the MCP directory API, please join our Discord server