Skip to main content

Excel MCP Server for manipulating Excel files

Project description

Excel MCP Tools Logo

PyPI version Total Downloads License: MIT

A Model Context Protocol (MCP) server that lets you manipulate Excel files without needing Microsoft Excel installed. Create, read, and modify Excel workbooks with your AI agent.

Features

  • 📊 Excel Operations: Create, read, update workbooks and worksheets
  • 📈 Data Manipulation: Formulas, formatting, charts, pivot tables, and Excel tables
  • 🔍 Data Validation: Built-in validation for ranges, formulas, and data integrity
  • 🎨 Formatting: Font styling, colors, borders, alignment, and conditional formatting
  • 📋 Table Operations: Create and manage Excel tables with custom styling
  • 📊 Chart Creation: Generate various chart types (line, bar, pie, scatter, etc.)
  • 🔄 Pivot Tables: Create dynamic pivot tables for data analysis
  • 🔧 Sheet Management: Copy, rename, delete worksheets with ease
  • 🔌 Triple transport support: stdio, SSE (deprecated), and streamable HTTP
  • 🌐 Remote & Local: Works both locally and as a remote service

Usage

The server supports three transport methods:

1. Stdio Transport (for local use)

uvx mcp-excel-tools stdio
{
   "mcpServers": {
      "excel": {
         "command": "uvx",
         "args": ["mcp-excel-tools", "stdio"]
      }
   }
}

2. SSE Transport (Server-Sent Events - Deprecated)

uvx mcp-excel-tools sse 

SSE transport connection:

{
   "mcpServers": {
      "excel": {
         "url": "http://localhost:8000/sse",
      }
   }
}

3. Streamable HTTP Transport (Recommended for remote connections)

uvx mcp-excel-tools streamable-http

Streamable HTTP transport connection:

{
   "mcpServers": {
      "excel": {
         "url": "http://localhost:8000/mcp",
      }
   }
}

Environment Variables & File Path Handling

SSE and Streamable HTTP Transports

When running the server with the SSE or Streamable HTTP protocols, you must set the EXCEL_FILES_PATH environment variable on the server side. This variable tells the server where to read and write Excel files.

  • If not set, it defaults to ./excel_files.

You can also set the FASTMCP_PORT environment variable to control the port the server listens on (default is 8017 if not set).

  • Example (Windows PowerShell):
    $env:EXCEL_FILES_PATH="E:\MyExcelFiles"
    $env:FASTMCP_PORT="8007"
    uvx mcp-excel-tools streamable-http
    
  • Example (Linux/macOS):
    EXCEL_FILES_PATH=/path/to/excel_files FASTMCP_PORT=8007 uvx mcp-excel-tools streamable-http
    

Stdio Transport

When using the stdio protocol, the file path is provided with each tool call, so you do not need to set EXCEL_FILES_PATH on the server. The server will use the path sent by the client for each operation.

set EXCEL_FILES_PATH can help agent as soon as possible to find the Excel file, actually every tool's env and base path diffent another one, but they should resolve the relative path to absolute path.

Available Tools

The server provides a comprehensive set of Excel manipulation tools. See TOOLS.md for complete documentation of all available tools.

Thanks

this project is based on excel-mcp-server, thanks for the original work.

License

MIT License - see LICENSE for details.

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_excel_tools-0.1.9.tar.gz (84.7 kB view details)

Uploaded Source

Built Distribution

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

mcp_excel_tools-0.1.9-py3-none-any.whl (30.7 kB view details)

Uploaded Python 3

File details

Details for the file mcp_excel_tools-0.1.9.tar.gz.

File metadata

  • Download URL: mcp_excel_tools-0.1.9.tar.gz
  • Upload date:
  • Size: 84.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.18

File hashes

Hashes for mcp_excel_tools-0.1.9.tar.gz
Algorithm Hash digest
SHA256 032ff1fd2e6c3fc4db8e2c1be5bb6459e758aafca302736f8d8e513c813cee1d
MD5 e6e81e3fcad331b9082b8372698a5d18
BLAKE2b-256 495368e08161393d9a76a6b664a93f0aaca39e9212f56aa77cf9d14229add204

See more details on using hashes here.

File details

Details for the file mcp_excel_tools-0.1.9-py3-none-any.whl.

File metadata

File hashes

Hashes for mcp_excel_tools-0.1.9-py3-none-any.whl
Algorithm Hash digest
SHA256 6b54d871f28ea8957c592c1fa02cf41dc6f06a1513a041a04ad973abc497bfc8
MD5 36fd0f13ce4c9024be6e6d00c0e11e73
BLAKE2b-256 eb38cb32e182cc3a7613c015cd0a6455cae07f8959a1b5554b64d2476d6d8e25

See more details on using hashes here.

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