Skip to main content

MCP server for Korean KOSIS OpenAPI statistics data

Project description

korean-stat-mcp

KOSIS OpenAPI 데이터를 MCP 클라이언트에서 바로 쓸 수 있게 만든 Python 서버입니다.

Claude Desktop, Claude Code, Cursor, Windsurf 같은 MCP 지원 도구에서 통계표를 검색하고, 메타데이터를 확인하고, 데이터를 가져와 간단한 분석까지 이어갈 수 있습니다.

English README

PyPI Python License: MIT CI

할 수 있는 일

  • KOSIS 통계표 키워드 검색
  • 기관/주제별 통계 목록 탐색
  • 통계표 분류, 항목, 수록 기간 같은 메타데이터 조회
  • 원천 데이터 조회, 필터링, 그룹 집계
  • 저장된 데이터 청크 읽기와 표/분석 헬퍼 제공
  • verify_statistics로 특정 수치가 KOSIS 원천 행과 맞는지 확인

KOSIS API는 테이블마다 필요한 파라미터가 조금씩 다르고, 기간/분기/지자체 데이터에서 예외가 자주 나옵니다. 이 서버는 그 부분을 MCP 도구 형태로 감싸서 클라이언트 쪽 설정을 줄이는 데 초점을 둡니다.

설치

먼저 KOSIS OpenAPI 키가 필요합니다. 키는 KOSIS OpenAPI 신청 페이지에서 발급받을 수 있습니다.

Claude Desktop / Cursor / Windsurf

pip install korean-stat-mcp

MCP 설정 파일에 아래 내용을 추가합니다.

{
  "mcpServers": {
    "korean-stat": {
      "command": "korean-stat-mcp",
      "env": {
        "KOSIS_API_KEY": "<KOSIS_API_KEY>"
      }
    }
  }
}

Claude Desktop의 macOS 설정 파일 위치:

~/Library/Application Support/Claude/claude_desktop_config.json

MCP 클라이언트 설정

{
  "mcpServers": {
    "korean-stat": {
      "command": "korean-stat-mcp",
      "env": {
        "KOSIS_API_KEY": "<KOSIS_API_KEY>"
      }
    }
  }
}

직접 실행

pip install korean-stat-mcp
export KOSIS_API_KEY="<KOSIS_API_KEY>"
korean-stat-mcp          # stdio MCP, 로컬 Claude Desktop/Cursor용
korean-stat-mcp --http   # Streamable HTTP 서버, http://localhost:8000/mcp

설치 확인:

korean-stat-mcp --version

원격 MCP로 호스팅하기

공식 호스팅 엔드포인트는 아직 없습니다. Claude.ai의 custom connector에서 쓰려면 직접 배포한 뒤 아래 형태의 URL을 등록합니다.

https://<your-host>/mcp

배포 예시는 deploy/README.md에 정리되어 있습니다. Docker, Fly.io, Render, Railway, DigitalOcean App Platform, 일반 VPS 배포를 다룹니다.

상태 확인:

curl https://<your-host>/health

주요 도구

구분 도구 용도
검색 search_statistics 키워드로 통계표 찾기
탐색 browse_categories 기관/주제별 목록 탐색
메타데이터 get_table_metadata, get_available_values 분류, 항목, 기간 확인
데이터 get_statistics_data KOSIS 원천 데이터 조회
가공 filter_statistics, aggregate_statistics 필터링, 그룹 집계
저장 데이터 read_stored_data, list_stored_data 큰 결과를 나눠 읽기
검증 verify_statistics 특정 수치와 원천 데이터 대조
출력 execute_table, execute_analysis 표 생성, 간단한 분석

전체 도구 목록과 이전 이름과의 매핑은 docs/TOOL_MIGRATION.md를 참고하세요.

환경변수

변수 필수 설명
KOSIS_API_KEY KOSIS OpenAPI 인증키
KOSIS_ARTIFACTS_DIR 아니오 로컬 차트/리포트 저장 경로
KOSIS_MCP_URL 아니오 자체 호스팅 인스턴스의 base URL

전체 예시는 .env.example에 있습니다.

검증 상태

  • Python 3.12 / 3.13 CI를 사용합니다.
  • 2026-04-30 기준 unit test는 449개가 통과했습니다.
  • KOSIS live pilot 100건에서 API 오류, timeout, parse 오류는 없었습니다. no_data 2건은 폐기되었거나 응답이 비어 있는 통계표로 분류했습니다.

자세한 내용은 docs/VALIDATION_REPORT.md에 있습니다.

문서

라이선스

코드는 MIT 라이선스로 배포됩니다. KOSIS 데이터 자체의 이용 조건은 KOSIS 국가통계포털 정책을 따릅니다.

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

korean_stat_mcp-0.1.3.tar.gz (176.3 kB view details)

Uploaded Source

Built Distribution

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

korean_stat_mcp-0.1.3-py3-none-any.whl (202.0 kB view details)

Uploaded Python 3

File details

Details for the file korean_stat_mcp-0.1.3.tar.gz.

File metadata

  • Download URL: korean_stat_mcp-0.1.3.tar.gz
  • Upload date:
  • Size: 176.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for korean_stat_mcp-0.1.3.tar.gz
Algorithm Hash digest
SHA256 d46f77729761543704ed275fe31d2a8db45b89496b43bd3146b56bd58b43e380
MD5 ec873e0f0c1a46efa88f8edcfcb46aac
BLAKE2b-256 5ff74040b01898fbc7f0eeee7e140bdc96ea84e1021088ab0ab27721a3c42753

See more details on using hashes here.

Provenance

The following attestation bundles were made for korean_stat_mcp-0.1.3.tar.gz:

Publisher: release.yml on seolcoding/korean-stat-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 korean_stat_mcp-0.1.3-py3-none-any.whl.

File metadata

  • Download URL: korean_stat_mcp-0.1.3-py3-none-any.whl
  • Upload date:
  • Size: 202.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for korean_stat_mcp-0.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 915aab0c9f359f92bb8cf3f4dda0264fb439c15f2cd38b168976bc14f8f433a5
MD5 f1ba2921125e58f813546ced7d377464
BLAKE2b-256 a67bd97a04aefe9f2a9ce3dc49077bfa4ebb6200d677b1a5329a3837ebb551c4

See more details on using hashes here.

Provenance

The following attestation bundles were made for korean_stat_mcp-0.1.3-py3-none-any.whl:

Publisher: release.yml on seolcoding/korean-stat-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