JUHE API Marketplace
jikime avatar
MCP Server

Python MCP Korea Weather Service

MCP server that provides Korean weather information using grid coordinates and the Korea Meteorological Administration API, allowing users to query current weather conditions and forecasts for specific locations in Korea.

3
GitHub Stars
8/23/2025
Last Updated
MCP Server Configuration
1{
2 "name": "Google Toolbox",
3 "command": "/path/to/bin/uv",
4 "args": [
5 "--directory",
6 "/path/to/py-mcp-ko-weather",
7 "run",
8 "src/server.py"
9 ]
10}
JSON10 lines

README Documentation

Korea Weather MCP Server

[

This MCP (Multi-platform Communication Protocol) server provides access to Korea Meteorological Administration (KMA) APIs, allowing AI agents to retrieve weather forecast information for locations in South Korea.

Overview

  • Retrieve precise grid coordinates for Korean administrative regions
  • Get detailed short-term weather forecasts for any location in Korea
  • Support for all Korean administrative divisions (city, district, neighborhood)
  • Structured text responses optimized for LLM consumption
  • Comprehensive weather data including temperature, precipitation, sky condition, humidity, wind direction, and wind speed

Table of Contents

Setup

Prerequisites

  • Python 3.12+
  • Korea Meteorological Administration API credentials
  • You can obtain the API credentials by signing up at the Public Data Portal and requesting access to the "기상청_단기예보 ((구)_동네예보) 조회서비스" API.

Installation

  1. Clone the repository:
git clone https://github.com/jikime/py-mcp-ko-weather.git
cd py-mcp-ko-weather
  1. uv installation
curl -LsSf https://astral.sh/uv/install.sh | sh
  1. Create a virtual environment and install dependencies:
uv venv -p 3.12
source .venv/bin/activate
uv pip install -r requirements.txt
  1. Create a .env file with your KMA API credentials:
cp env.example .env
vi .env

KO_WEATHER_API_KEY=your_api_key_here
  1. Migrate the grid coordinates data from Excel to SQLite:
uv run src/migrate.py

Using Docker

  1. Build the Docker image:
docker build -t py-mcp-ko-weather .
  1. Run the container:
docker run py-mcp-ko-weather

Using Local

  1. Run the server:
mcp run src/server.py
  1. Run the MCP Inspector
mcp dev server.py

Configure MCP Settings

Add the server configuration to your MCP settings file:

Claude desktop app

  1. To install automatically via Smithery:
npx -y @smithery/cli install @jikime/py-mcp-ko-weather --client claude
  1. To install manually open ~/Library/Application Support/Claude/claude_desktop_config.json

Add this to the mcpServers object:

{
  "mcpServers": {
    "Google Toolbox": {
      "command": "/path/to/bin/uv",
      "args": [
        "--directory",
        "/path/to/py-mcp-ko-weather",
        "run",
        "src/server.py"
      ]
    }
  }
}

Cursor IDE

open ~/.cursor/mcp.json

Add this to the mcpServers object:

{
  "mcpServers": {
    "Google Toolbox": {
      "command": "/path/to/bin/uv",
      "args": [
        "--directory",
        "/path/to/py-mcp-ko-weather",
        "run",
        "src/server.py"
      ]
    }
  }
}

for Docker

{
  "mcpServers": {
    "Google Toolbox": {
      "command": "docker",
      "args": [
        "run",
        "-i",
        "--rm",
        "py-mcp-ko-weather"
      ]
    }
  }
}

Using with Claude

Once configured, you can ask Claude questions like:

  • "서울특별시 서초구 양재1동의 날씨는?"
  • "부산광역시 해운대구 우동의 날씨 예보를 알려줘"
  • "경기도 성남시 분당구의 현재 기온은?"

API Reference

Tools

Get Grid Location

get_grid_location(city: str, gu: str, dong: str) -> dict

Retrieves the grid coordinates (nx, ny) used by the Korea Meteorological Administration API for the specified location. This tool searches the database for the exact coordinates based on city/province, district/county, and neighborhood/town information.

Get Forecast

get_forecast(city: str, gu: str, dong: str, nx: int, ny: int) -> str

Calls the KMA's ultra-short-term forecast API to provide weather forecast information for a specific location. Returns comprehensive weather data including temperature, precipitation, sky condition, humidity, wind direction, and wind speed.

Resources

Weather Instructions

GET weather://instructions

Provides detailed documentation on how to use the Korea Weather MCP server, including tool workflows and response formats.

Prompts

Weather Query

The server includes a structured prompt template for guiding conversations about weather queries, ensuring efficient information gathering and clear presentation of forecast data.

Response Format

Weather forecast responses are provided in structured text format, optimized for LLM processing:

Weather forecast for 서울특별시 서초구 양재1동 (coordinates: nx=61, ny=125)
Date: 2025-05-01
Time: 15:00

Current conditions:
Temperature: 22.3°C
Sky condition: Mostly clear
Precipitation type: None
Precipitation probability: 0%
Humidity: 45%
Wind direction: Northwest
Wind speed: 2.3 m/s

Hourly forecast:
16:00 - Temperature: 21.8°C, Sky: Clear, Precipitation: None
17:00 - Temperature: 20.5°C, Sky: Clear, Precipitation: None
18:00 - Temperature: 19.2°C, Sky: Clear, Precipitation: None
...

Acknowledgements

License

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

Quick Install

Quick Actions

Key Features

Model Context Protocol
Secure Communication
Real-time Updates
Open Source