Skip to main content

Let Claude query Excel files using SQL - no SQL knowledge required

Project description

mcp-server-excel-sql

PyPI version License: MIT MCP Server Test

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:

  1. Point the server at your Excel/CSV files
  2. Ask Claude questions in plain English
  3. Claude writes SQL queries automatically
  4. 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)

Claude analyzing Excel budget data

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 Summarysales.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

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

mcp_server_excel_sql-0.7.6.tar.gz (1.4 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

mcp_server_excel_sql-0.7.6-py3-none-any.whl (40.0 kB view details)

Uploaded Python 3

File details

Details for the file mcp_server_excel_sql-0.7.6.tar.gz.

File metadata

  • Download URL: mcp_server_excel_sql-0.7.6.tar.gz
  • Upload date:
  • Size: 1.4 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for mcp_server_excel_sql-0.7.6.tar.gz
Algorithm Hash digest
SHA256 ab7c84df579be22ba6d72292dc2a97653af878b0ad8e6a13d9ac1873d8457f89
MD5 302dd527a874e3b1f5302c84c3ae7e53
BLAKE2b-256 b38b6ec578aa6a799646c3de8049e8deea3ac3aae2513f3dfe176c1f9eebf404

See more details on using hashes here.

Provenance

The following attestation bundles were made for mcp_server_excel_sql-0.7.6.tar.gz:

Publisher: publish.yml on ivan-loh/mcp-excel

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file mcp_server_excel_sql-0.7.6-py3-none-any.whl.

File metadata

File hashes

Hashes for mcp_server_excel_sql-0.7.6-py3-none-any.whl
Algorithm Hash digest
SHA256 261a55fda5b0d96fd1d4dcbd869f45f14d8aee39703a2d2ec268477cbf8c8ba9
MD5 576bd0282209238ca04d70a1fc32c8ca
BLAKE2b-256 22d6e1dac026f861bdcc73e48aad4b5c5b9170777eb2497efdd355c3dab91d81

See more details on using hashes here.

Provenance

The following attestation bundles were made for mcp_server_excel_sql-0.7.6-py3-none-any.whl:

Publisher: publish.yml on ivan-loh/mcp-excel

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page