Skip to main content

MCP Server for NetCDF format file

Project description

NetCDF Explorer MCP Server

A simple and powerful MCP (Message Communication Protocol) server for exploring, analyzing, and interacting with NetCDF format files. Designed to simplify NetCDF data management with intuitive APIs and efficient data handling.

Overview

NetCDF (Network Common Data Form) is a widely used format for storing scientific data. This MCP server provides a streamlined interface to work with NetCDF files, offering essential functionalities to list files, inspect structures, extract data, and analyze variables—all while handling large datasets efficiently through smart sampling.

Features

  • 📁 File Discovery: List all NetCDF files (.nc, .cdf, .netcdf, .nc4) in a specified directory.
  • 🔍 Structure Inspection: Retrieve detailed metadata of NetCDF files, including dimensions, variables, attributes, and global properties.
  • 📊 Data Extraction: Read variable data with support for flexible slicing (e.g., lat: "0:10:2" to extract subsets).
  • 🧠 Smart Sampling: Automatically sample large datasets to prevent memory overflow, with configurable element limits.
  • Time Series Analysis: Extract temporal data from spatial variables, with optional custom location coordinates.
  • 🔎 Search Functionality: Find variables and attributes by keyword, simplifying navigation in complex files.
  • 📋 Variable Summaries: Generate human-readable summaries of variables, including dimensions, data types, and attributes.

Installation

Prerequisites

  • Python ≥ 3.13

Install via pip

pip install nc-mcp

Install from Source

  1. Clone the repository:

    git clone https://github.com/HanchaoLi/nc-mcp.git
    cd nc-mcp
    
  2. Install dependencies (using uv for faster dependency management):

    # Install uv (if not already installed)
    curl -LsSf https://astral.sh/uv/install.sh | sh
    
    # Sync dependencies
    uv sync --all-groups
    

Quick Start

Start the Server

python -m nc_mcp_server.main

API Reference

Core Functions

Function Description Parameters
list_netcdf_files Lists all NetCDF files in a directory. directory (str): Path to search (default: .).
get_netcdf_info Returns metadata and structure of a NetCDF file (dimensions, variables, attributes). file_path (str): Path to the NetCDF file.
get_variable_data Extracts data from a specific variable (supports slicing and sampling). file_path (str), variable_name (str), slices (dict, optional), max_elements (int, default: 1000).
search_variables Searches variables and attributes for a keyword (case-insensitive). file_path (str), search_term (str).
extract_timeseries Extracts time series data from a spatial variable. file_path (str), variable_name (str), location (dict, optional: spatial coordinates like {"lat": 10, "lon": 20}).

Testing

Run the test suite to verify functionality:

uv run pytest tests/ -v

Tests cover:

  • File discovery logic
  • NetCDF structure parsing
  • Data extraction with slicing
  • Sampling for large datasets
  • Error handling for invalid inputs

License

This project is licensed under the MIT License. See the LICENSE file for details.

Contributing

  1. Fork the repository
  2. Create a feature branch (git checkout -b feature/amazing-feature)
  3. Commit your changes (git commit -m 'Add some amazing feature')
  4. Push to the branch (git push origin feature/amazing-feature)
  5. Open a Pull Request

Links

Author

John Li

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

nc_mcp-0.1.2.tar.gz (9.3 kB view details)

Uploaded Source

Built Distribution

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

nc_mcp-0.1.2-py3-none-any.whl (7.3 kB view details)

Uploaded Python 3

File details

Details for the file nc_mcp-0.1.2.tar.gz.

File metadata

  • Download URL: nc_mcp-0.1.2.tar.gz
  • Upload date:
  • Size: 9.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for nc_mcp-0.1.2.tar.gz
Algorithm Hash digest
SHA256 4c3f4d8049619a26070af1807c8715eec89e1395cbf89b12c4fa47bd6cd7de66
MD5 9930474dcd5061359c837323493499ec
BLAKE2b-256 0416989507fd3f77570412da1a678b6305fdcb407292e87800e59d8a3c8c44e1

See more details on using hashes here.

Provenance

The following attestation bundles were made for nc_mcp-0.1.2.tar.gz:

Publisher: publish.yml on HanchaoLi/nc-mcp

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file nc_mcp-0.1.2-py3-none-any.whl.

File metadata

  • Download URL: nc_mcp-0.1.2-py3-none-any.whl
  • Upload date:
  • Size: 7.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for nc_mcp-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 eca8b4455a0f333f7422661271a34758b954187cf94895ed42c53a36fa082367
MD5 b7325b45d969f2d7b0f00b16a86a0eb0
BLAKE2b-256 ae41bb182533fbdf8193f36bdced6b0272581c4d854f34550bbcd675911ca15b

See more details on using hashes here.

Provenance

The following attestation bundles were made for nc_mcp-0.1.2-py3-none-any.whl:

Publisher: publish.yml on HanchaoLi/nc-mcp

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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