The MCP Excel Reader server allows you to read and process Excel files efficiently with the following capabilities:
Read Excel Files: Extract data from
.xlsxand.xlsformatsAutomatic Chunking: Handle large datasets by splitting them into manageable chunks
Sheet Selection: Specify a sheet by name or default to the first sheet
Row Pagination: Control reading with
startRowandmaxRowsparametersStructured Data: Returns organized data with metadata about sheets, rows, and columns
Error Handling: Validates files and gracefully handles formatting issues
MCP Integration: Works seamlessly with MCP-compatible AI tools like Claude
MCP Excel Reader
A Model Context Protocol (MCP) server for reading Excel files with automatic chunking and pagination support. Built with SheetJS and TypeScript, this tool helps you handle large Excel files efficiently by automatically breaking them into manageable chunks.
Features
📊 Read Excel files (.xlsx, .xls) with automatic size limits
🔄 Automatic chunking for large datasets
📑 Sheet selection and row pagination
📅 Proper date handling
⚡ Optimized for large files
🛡️ Error handling and validation
Related MCP server: Excel MCP Server
Installation
Installing via Smithery
To install Excel Reader for Claude Desktop automatically via Smithery:
As an MCP Server
Install globally:
Add to your MCP settings file (usually at
~/.config/claude/settings.jsonor equivalent):
For Development
Clone the repository:
Install dependencies:
Build the project:
Usage
Usage
The Excel Reader provides a single tool read_excel with the following parameters:
Basic Usage
When used with Claude or another MCP-compatible AI:
The AI will use the tool to read the file, automatically handling chunking for large files.
Features
Automatic Chunking
Automatically splits large files into manageable chunks
Default chunk size of 100KB
Provides metadata for pagination
Sheet Selection
Read specific sheets by name
Defaults to first sheet if not specified
Row Pagination
Control which rows to read with startRow and maxRows
Get next chunk information for continuous reading
Error Handling
Validates file existence and format
Provides clear error messages
Handles malformed Excel files gracefully
Extending with SheetJS Features
The Excel Reader is built on SheetJS and can be extended with its powerful features:
Available Extensions
Formula Handling
// Enable formula parsing const wb = XLSX.read(data, { cellFormula: true, cellNF: true });Cell Formatting
// Access cell styles and formatting const styles = Object.keys(worksheet) .filter(key => key[0] !== '!') .map(key => ({ cell: key, style: worksheet[key].s }));Data Validation
// Access data validation rules const validation = worksheet['!dataValidation'];Sheet Features
Merged Cells:
worksheet['!merges']Hidden Rows/Columns:
worksheet['!rows'],worksheet['!cols']Sheet Protection:
worksheet['!protect']
For more features and detailed documentation, visit the SheetJS Documentation.
Contributing
Fork the repository
Create your feature branch (
git checkout -b feature/amazing-feature)Commit your changes (
git commit -m 'Add some amazing feature')Push to the branch (
git push origin feature/amazing-feature)Open a Pull Request
License
This project is licensed under the MIT License - see the LICENSE file for details.
Acknowledgments
Built with SheetJS
Part of the Model Context Protocol ecosystem