A Model Context Protocol (MCP) server that provides comprehensive cricket data from Cricbuzz. This server offers real-time cricket statistics, player information, match schedules, and news updates.
- Player Statistics: Get detailed cricket player stats including batting and bowling records across all formats (Test, ODI, T20)
- Live Matches: Fetch currently ongoing cricket matches
- Match Schedule: Get upcoming cricket match schedules
- Cricket News: Latest cricket news and updates
- ICC Rankings: Official ICC rankings for batting, bowling, all-rounders, and teams across Test, ODI, and T20 formats
- Match Scorecards: Detailed match analysis with batting and bowling statistics
- Clone or download this repository
- Install the required dependencies:
pip install -r requirements.txt
You can interact with the Cricket MCP Server using a conversational web interface powered by Gradio and Gemini.
You need a Google Gemini API key to use the conversational agent. Set it as an environment variable:
export GOOGLE_API_KEY="your-gemini-api-key"
python3 cricket_gradio.py
This will launch a web UI in your browser where you can chat with the cricket assistant, ask for stats, live matches, news, and more.
Tip: The chat UI supports conversation memory and rich responses.
The server can be integrated with MCP clients. Here's how to configure it:
{
"cricket": {
"command": "python3",
"args": ["cricket_server.py"],
"transport": "stdio",
}
}
For a more flexible setup, you can use environment variables to define the python executable and server script path.
For testing purposes, you can run the server directly:
python3 cricket_server.py
Get comprehensive cricket player statistics.
Parameters:
player_name
(str): Name of the cricket playermatch_format
(str, optional): Specific format ("Test", "ODI", "T20"). If not provided, returns all formats.
Returns:
- Player basic info (name, country, role, image)
- ICC rankings for batting and bowling
- Detailed batting statistics
- Detailed bowling statistics
Example:
# Get all stats for a player
stats = get_player_stats("Virat Kohli")
# Get only T20 stats
t20_stats = get_player_stats("Virat Kohli", "T20")
Get currently live cricket matches.
Returns: List of live match information including teams and current status.
Get upcoming cricket match schedule.
Returns: List of upcoming international cricket matches with dates and details.
Get the latest cricket news.
Returns: List of cricket news articles with headlines, descriptions, timestamps, and categories.
Get official ICC cricket rankings for various categories.
Parameters:
category
(str): The ranking category. Must be one of: "batting", "bowling", "all-rounder", or "teams".
Returns: Dictionary with rankings for Test, ODI, and T20 formats. Each format contains a list of players or teams with their position, name, country, and rating.
Example:
# Get batting rankings
batting_rankings = get_icc_rankings("batting")
# Get bowling rankings
bowling_rankings = get_icc_rankings("bowling")
# Get team rankings
team_rankings = get_icc_rankings("teams")
Get detailed scorecard for a specific cricket match.
Parameters:
match_url
(str): The URL of the match on Cricbuzz (can be obtained from get_live_matches).
Returns: Dictionary containing match details including match title, result, and detailed scorecard for each innings with batting and bowling statistics.
This server scrapes data from Cricbuzz.com and uses Google Search for player profile discovery. Please ensure you comply with the website's terms of service and use responsibly.
fastmcp
: MCP server frameworkrequests
: HTTP library for web scrapingbeautifulsoup4
: HTML parsing librarylxml
: XML/HTML parsergooglesearch-python
: Google search API wrapper
The server runs on stdio transport by default. No additional configuration is required for basic usage.
The server includes comprehensive error handling for:
- Network connectivity issues
- Invalid player names
- Missing data on Cricbuzz
- Search failures
Add this badge to your README to show your server is listed and safe:
This project is licensed under the MIT License. See the LICENSE file for details.
Feel free to submit issues and enhancement requests!
This tool scrapes data from public websites. The authors are not responsible for any misuse or violation of website terms of service. Use responsibly and ensure compliance with applicable terms and conditions.