jona-mhw/google-sheets-mcp
If you are the rightful owner of google-sheets-mcp and would like to certify it and/or have it hosted online, please leave a comment on the right or send an email to dayong@mcphub.com.
The Google Sheets MCP Server is a Python-based server that facilitates secure and efficient interaction between Claude Desktop and Google Sheets using Google Apps Script.
📊 Google Sheets MCP Server
🐍 Python-based MCP Server that enables Claude Desktop to interact seamlessly with Google Sheets through Google Apps Script.
🔬 Research Project: This is an experimental development project demonstrating Model Context Protocol (MCP) capabilities and secure Google API integration. Developed as a proof of concept to explore new ways of connecting AI with productivity tools.
✨ Features
- 📖 Read Operations: Single cells, ranges, and sheet metadata
- ✏️ Write Operations: Update cells and ranges with data
- 🧹 Utility Operations: Clear ranges and test connections
- 🔐 Secure: Uses Google Apps Script as secure proxy within your own account
- 🚀 Easy Setup: Works with Claude Desktop without complex configurations
🔒 Security & Privacy
🛡️ Multiple Security Layers
-
Google Apps Script (Your Account):
- Runs in YOUR Google infrastructure
- Only YOU have access to your data
- Automatic authentication with your Google session
- No exposed OAuth credentials
-
Model Context Protocol (MCP):
- Open standard protocol by Anthropic
- Secure localhost-only communication
- No data transmitted to third parties
- Full control over exposed tools
-
Local Architecture:
- MCP server runs on YOUR machine
- No data leaves your control
- No external servers involved
🎯 Why is it Secure?
YOUR DATA → Google Sheets (YOUR account) → Apps Script (YOUR account) → MCP Server (YOUR machine) → Claude Desktop (YOUR machine)
Result: Your data NEVER leaves your personal ecosystem.
🚀 Quick Start
Prerequisites
- Python 3.8+ installed
- Claude Desktop installed
- Google account with access to Google Sheets and Apps Script
Installation
# 1. Clone this repository
git clone https://github.com/jona-mhw/google-sheets-mcp.git
cd google-sheets-mcp
# 2. Install Python dependencies
cd mcp-server
pip install -r requirements.txt
# 3. Configure environment variables
cp .env.example .env
# Edit .env and add your APPS_SCRIPT_URL
Google Apps Script Setup
Step 1: Create Apps Script Project
- Go to script.google.com
- Click "New project"
- Important: The file name can be anything (
Code.gs,main.gs,sheets.gs, etc.)
Step 2: Copy the Code
- Delete the default code
- Copy ALL content from
- Paste it into your project
- Save the project (Ctrl+S)
Step 3: Deploy as Web App
- Click "Deploy" > "New deployment"
- Type: Select "Web app"
- Configuration:
- Execute as: "Me" (your account)
- Who has access: "Anyone"
- Click "Deploy"
⚠️ Costs: Google Apps Script is FREE up to 6 hours of execution time per day. For normal spreadsheet usage, this is more than sufficient.
Step 4: Get the URL
- Copy the Web app URL (ends with
/exec) - This is your
APPS_SCRIPT_URL
Claude Desktop Configuration
-
Find your configuration file:
- macOS:
~/Library/Application Support/Claude/claude_desktop_config.json - Windows:
%APPDATA%/Claude/claude_desktop_config.json - Linux:
~/.config/Claude/claude_desktop_config.json
- macOS:
-
Add the MCP configuration:
{
"mcpServers": {
"google-sheets": {
"command": "python",
"args": ["server.py"],
"cwd": "/absolute/path/to/google-sheets-mcp/mcp-server",
"env": {
"APPS_SCRIPT_URL": "https://script.google.com/macros/s/YOUR_SCRIPT_ID/exec",
"DEBUG": "false"
}
}
}
}
⚠️ Important: Replace /absolute/path/to/ with the actual path where you cloned this repository.
Path examples:
- macOS/Linux:
/Users/your-username/google-sheets-mcp/mcp-server - Windows:
C:\\Users\\your-username\\google-sheets-mcp\\mcp-server
- Restart Claude Desktop
🛠️ Available Tools
| Tool | Description | Example Usage |
|---|---|---|
read_cell | Read a single cell | read_cell("Sheet1", "A1") |
write_cell | Write to a cell | write_cell("Sheet1", "A1", "Hello") |
read_range | Read cell range | read_range("Sheet1", "A1:B5") |
write_range | Write to range | write_range("Sheet1", "A1:B2", data) |
clear_range | Clear cell range | clear_range("Sheet1", "A1:B5") |
list_sheets | List all sheets | list_sheets() |
test_connection | Test setup | test_connection() |
🏗️ Architecture
Claude Desktop → Python MCP Server → Google Apps Script → Google Sheets
↑ ↓
←←←←←←←←←← JSON Response ←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←
Why this approach?
- 🔐 No complex OAuth: Apps Script uses your existing Google session
- 🎯 Focused: Designed specifically for Google Sheets operations
- 🚀 Scalable: Easy to add new functionality
- 💰 Free: Uses Google's free Apps Script infrastructure
- 🛡️ Private: Everything stays within your personal account
✅ Verification
After setup, ask Claude:
"Test the Google Sheets connection"
Claude should be able to use the test_connection() tool and show you it's connected.
🔍 Troubleshooting
Error: "No module named 'fastmcp'"
pip install -r requirements.txt
Error: "APPS_SCRIPT_URL not configured"
- Verify that the
.envfile exists - Verify that the URL is correct
- Ensure the Apps Script is deployed as Web App
Claude doesn't see the MCP
- Verify that the
cwdpath is absolute and correct - Restart Claude Desktop completely
- Check that the JSON configuration is valid
Apps Script permission errors
- Ensure the Apps Script is deployed with "Anyone" permissions
- Verify that the Spreadsheet exists and you have access
🤝 Contributing
- Fork the repository
- Create your feature branch (
git checkout -b feature/amazing-feature) - Commit your changes (
git commit -m 'Add 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 file for details.
🙏 Acknowledgments
- Built with FastMCP
- Integrates with Google Apps Script
- Part of the Model Context Protocol ecosystem
Created by: Jona
Purpose: Connect Claude with Google Sheets efficiently and securely
Type: Research & Development Project - MCP Proof of Concept