mcp-excel
Enables querying Excel and CSV files using SQL via natural language, allowing AI assistants to analyze data without manual SQL writing.
README
mcp-server-excel-sql
Let Claude query your Excel and CSV files using SQL - no SQL knowledge required. Ask questions in plain English, Claude writes and executes the queries automatically.
What It Does
How it works:
- Point the server at your Excel/CSV files
- Ask Claude questions in plain English
- Claude writes SQL queries automatically
- Get instant answers from your data
Capabilities:
- Each Excel sheet and CSV file becomes a queryable SQL table
- Join data across multiple files and formats (xlsx, xls, csv, tsv)
- Clean messy data with YAML transformation rules
- Deploy for teams with concurrent access
- Support for complex queries (aggregations, window functions, CTEs)

Should You Use This?
Great fit if you:
- Work with Excel files under 100MB
- Want data insights without SQL knowledge
- Need to join multiple spreadsheets
- Use AI assistants (Claude writes the SQL for you)
- Prototype before building ETL pipelines
Not the right tool if you:
- Have files over 100MB (use database import instead)
- Need to modify Excel files (read-only)
- Need formulas/macros/VBA (values only)
- Building production data warehouse (prototyping only)
Installation
Install uv:
curl -LsSf https://astral.sh/uv/install.sh | sh
That's it. No package installation needed - uvx runs the server on-demand.
Try It Now
git clone https://github.com/ivan-loh/mcp-excel.git
cd mcp-excel
python examples/finance/create_finance_examples.py
uvx --from mcp-server-excel-sql mcp-excel --path examples/finance
Quick Start
Claude Desktop
Add to ~/Library/Application Support/Claude/claude_desktop_config.json:
{
"mcpServers": {
"excel": {
"command": "uvx",
"args": [
"--from", "mcp-server-excel-sql", "mcp-excel",
"--path", "/path/to/excel/files/"
]
}
}
}
Update the path and restart Claude Desktop.
Command Line Testing
# Test with your files
uvx --from mcp-server-excel-sql mcp-excel --path /path/to/excel/files
# With auto-refresh
uvx --from mcp-server-excel-sql mcp-excel --path /path/to/files --watch
Common Use Cases
- Financial Analysis - Budget vs actuals, AR aging, revenue trending
- Sales Reporting - Territory performance, product analysis, customer segmentation
- Operations - Inventory reconciliation, vendor comparison, project tracking
- Data Exploration - Quick SQL access, data quality testing, analytics prototyping
Available Tools
- tool_list_tables - Lists all tables and views with file paths and row counts
- tool_get_schema - Shows column names and types for a table or view
- tool_query - Execute read-only SQL queries (joins, aggregations, CTEs)
- tool_refresh - Reload data after file changes (automatic with --watch)
- tool_create_view - Create persistent SQL views that survive restarts
- tool_drop_view - Delete a view and its storage
Understanding Table Names
Tables are named: <alias>.<filename>.<sheet> (lowercase, sanitized)
Example: File /data/sales/Q1-2024.xlsx sheet Summary → sales.q12024.summary
Important: Always quote table names in SQL:
SELECT * FROM "sales.q12024.summary" -- Correct
System Views
<alias>.__files- File inventory (paths, sheet count, rows, modification time)<alias>.__tables- Table catalog (names, source file, sheet, row count)
Persistent Views
Create reusable SQL views stored on disk that automatically restore on server restart.
Example:
CREATE VIEW high_value_sales AS
SELECT * FROM "sales.data.summary" WHERE amount > 1000
Use for filtering, aggregations, or multi-table joins. Manage with tool_create_view(), tool_drop_view(), and tool_list_tables().
Data Transformation
Clean messy Excel files with YAML transformation rules:
Capabilities:
- Skip header/footer rows, combine multi-row headers
- Filter rows with regex or column conditions
- Rename columns, set data types (dates, decimals)
- Pivot wide to long format, specify cell ranges
- Extract tables from multi-table sheets
Usage:
uvx --from mcp-server-excel-sql mcp-excel --path /data --overrides config.yaml
See examples/finance/finance_overrides.yaml for complete configuration examples.
Auto-Detection Features
Handle complex Excel files automatically without manual configuration.
What it detects:
- Merged cells, hidden rows/columns
- European number formats (1.234,56 → decimals)
- Multiple tables on single sheets
- Header rows, metadata rows
Enable:
messy_report.xlsx:
sheet_overrides:
"Report":
auto_detect: true
Use for: Merged cell headers, hidden columns, European formatting, multi-table sheets, complex layouts.
Limitation: .xlsx and .xlsm only. See DEVELOPMENT.md for advanced options.
CLI Options
uvx --from mcp-server-excel-sql mcp-excel [OPTIONS]
Options:
--path- Directory containing Excel files (default: current directory)--overrides- YAML configuration file for transformations--watch- Auto-refresh when files change--transport- Communication mode:stdio,streamable-http,sse(default: stdio)--host- Host for HTTP/SSE (default: 127.0.0.1)--port- Port for HTTP/SSE (default: 8000)--require-auth- Enable API key authentication (uses MCP_EXCEL_API_KEY env var)
Additional Documentation
Multi-user deployment, security, and development: See DEVELOPMENT.md for:
- Multi-user setup with authentication
- Security model and enforcement
- Architecture and design decisions
- Performance characteristics
- Testing and development workflow
Examples: See examples/README.md for finance and CNC datasets with detailed query examples.
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.