gurufocus-mcp
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@gurufocus-mcpGet stock summary for AAPL"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
Unofficial GuruFocus MCP Server & Python API Library
NOTE: This repo is currently a work in progress and is not yet ready for production use.
A comprehensive GuruFocus MCP server and Python API client library with Pydantic models for all responses.
Packages
This monorepo contains two packages:
gurufocus-api
A standalone Python client library for the GuruFocus API.
Full API coverage with type hints
Three-tier earnings-aware caching
Rate limiting and retry logic
Pydantic models for all responses
Async-first design with
httpx
gurufocus-mcp
An MCP server exposing GuruFocus data to AI assistants.
FastMCP framework with HTTP/SSE transport
50+ tools for stocks, gurus, insiders, politicians, economic data, and more
Resources for direct data access
TOON format support for 30-60% token reduction in LLM contexts
Quick Start
Installation
# Install both packages
pip install gurufocus-api gurufocus-mcpUsing the API Client
from gurufocus_api import GuruFocusClient
async with GuruFocusClient() as client:
summary = await client.get_summary("AAPL")
print(summary.gf_score)Running the MCP Server
export GURUFOCUS_API_TOKEN=your-token
gurufocus-mcpClaude Desktop Integration
First, install the package:
pipx install gurufocus-mcp # recommended for CLI tools
# or
pip install gurufocus-mcpThen add to your Claude Desktop configuration file:
macOS: ~/Library/Application Support/Claude/claude_desktop_config.json
Windows: %APPDATA%\Claude\claude_desktop_config.json
{
"mcpServers": {
"gurufocus": {
"command": "gurufocus-mcp",
"env": {
"GURUFOCUS_API_TOKEN": "your-token-here"
}
}
}
}After adding the configuration, restart Claude Desktop. You should see the GuruFocus tools available in Claude's interface.
Running from source (for development):
{
"mcpServers": {
"gurufocus": {
"command": "uv",
"args": ["run", "gurufocus-mcp"],
"env": {
"GURUFOCUS_API_TOKEN": "your-token-here"
}
}
}
}Output Format (TOON)
The MCP server supports TOON format for token-efficient responses, achieving 30-60% reduction in token usage compared to JSON.
Per-request format selection:
All tools accept a format parameter:
"toon"(default) - Token-efficient format optimized for LLM contexts"json"- Standard JSON format for debugging or compatibility
# TOON format (default)
result = await client.call_tool("get_stock_summary", {"symbol": "AAPL"})
# JSON format
result = await client.call_tool("get_stock_summary", {"symbol": "AAPL", "format": "json"})Environment variable configuration:
# Change the default output format (default: toon)
export GURUFOCUS_DEFAULT_OUTPUT_FORMAT=jsonConfiguration
All settings can be configured via environment variables with the GURUFOCUS_ prefix.
Required
Variable | Description |
| Your GuruFocus API token |
Cache Settings
Variable | Default | Description |
|
| Enable response caching |
|
| Directory for cache storage |
Recommended: Set an absolute path for GURUFOCUS_CACHE_DIR to ensure consistent caching across sessions:
export GURUFOCUS_CACHE_DIR="$HOME/.cache/gurufocus-mcp"Or in Claude Desktop config:
{
"mcpServers": {
"gurufocus": {
"command": "gurufocus-mcp",
"env": {
"GURUFOCUS_API_TOKEN": "your-token-here",
"GURUFOCUS_CACHE_DIR": "/Users/yourname/.cache/gurufocus-mcp"
}
}
}
}Rate Limiting
Variable | Default | Description |
|
| Enable rate limiting |
|
| Maximum requests per minute |
|
| Maximum requests per day (0 = unlimited) |
API Settings
Variable | Default | Description |
|
| API base URL |
|
| Request timeout in seconds |
|
| Maximum retry attempts for failed requests |
Output Format
Variable | Default | Description |
|
| Default format: |
Logging
Variable | Default | Description |
|
| Logging level: |
|
| Log format: |
Development
Setup
# Clone the repository
git clone https://github.com/yourorg/gurufocus-mcp.git
cd gurufocus-mcp
# Install uv if not already installed
curl -LsSf https://astral.sh/uv/install.sh | sh
# Install dependencies
uv sync --all-packages
# Run tests
uv run pytest
# Run tests with coverage
uv run pytest --cov --cov-report=html --junitxml=junit.xml
# Run linting
uv run ruff check .Project Structure
gurufocus-mcp/
├── packages/
│ ├── gurufocus-api/ # Python API client
│ └── gurufocus-mcp/ # MCP server
├── docs/ # Documentation
├── examples/ # Usage examples
└── pyproject.toml # Workspace configDisclaimer
This project is an unofficial tool and is not affiliated with, endorsed by, or sponsored by GuruFocus.com, LLC or any of its subsidiaries.
Non-Affiliation: This software is developed independently and does not represent the views or opinions of GuruFocus.
Trademarks: "GuruFocus" and the GuruFocus logo are trademarks of GuruFocus.com, LLC.
Data Usage: Users are responsible for ensuring their use of this tool complies with the GuruFocus Terms of Use and any applicable API usage agreements. This tool is provided "as is" and intended for educational and personal use.
No Warranty: The authors of this software make no warranty as to the accuracy, completeness, or reliability of the data retrieved using this tool.
No Investment Advice: The information provided by this tool is for informational and educational purposes only and does not constitute investment advice, financial advice, trading advice, or any other sort of advice. You should not treat any of the tool's content as such.
External Methodologies: References to third-party investment strategies, books, authors, or personalities (e.g., Phil Town, Rule #1, Warren Buffett) are for educational purposes to demonstrate the application of published methodologies. This project is not affiliated with, endorsed by, or sponsored by any referenced individuals or entities. All trademarks belong to their respective owners.
License
MIT
This server cannot be installed
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/u-daveblack/gurufocus-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server