Skip to main content

MCP server exposing Japan-specific utilities (era conversion, romaji, holidays, postal codes) to AI agents.

Project description

japan-utils-mcp

MCP server exposing Japan-specific utilities to AI agents (Claude, Cursor, Cline, Continue, etc.). Hand your agent the small bag of JP-specific functions every Japan-related task needs but no generic LLM gets right reliably:

  • 🗓️ Era ↔ Western year令和8年2026
  • 🔤 Kanji → Hepburn romaji山田太郎yamada tarou
  • 📮 Postal code lookup150-0001東京都 渋谷区 神宮前
  • 🎌 National holiday calendar — is 2026-05-03 a holiday? what about all of 2026?
  • 🅰️ Kana conversion — hiragana ↔ katakana ↔ half-width katakana
  • 📏 Width normalization — full-width (全角) ↔ half-width (半角) for ASCII, digits, kana
  • 👤 Name splitting山田太郎 → surname 山田 + given 太郎 (statistical model)

Built on top of well-maintained Japanese libraries (jpholiday, posuto, pykakasi, jaconv, namedivider-python) — wrapped as MCP tools so any AI agent can call them without re-implementing reading rules, era arithmetic, postal data, or name-splitting heuristics.

Why this exists

Generic LLMs hallucinate on JP-specific data:

  • "What year is 令和8年?" — often wrong
  • "Convert 山田太郎 to romaji" — gets the surname wrong half the time
  • "What's the address for postal code 150-0001?" — fabricates plausible-looking nonsense
  • "Is May 3rd a Japanese holiday?" — guesses

This MCP gives them a deterministic answer.

Tools

Tool What it does
era_to_western 令和8年 / R8 / Reiwa 8 / 令和元年 → Gregorian year + era metadata
western_to_era 2026 → era kanji (令和), English (Reiwa), year-of-era (8), formatted strings
kanji_to_romaji Mixed Japanese text → Hepburn romaji + hiragana reading
lookup_postal_code 7-digit JP postal code → prefecture / city / area, with kana readings
is_holiday Date string → is it a national holiday? + Japanese name + weekday
list_holidays Year → all national holidays for that year
convert_kana hiragana ↔ katakana ↔ half-width katakana, any direction
normalize_width Full-width ↔ half-width for ASCII, digits, kana (with per-category control)
split_japanese_name Japanese full name → surname + given name (statistical model with confidence)

All tools return structured JSON. See tool docstrings in src/japan_utils_mcp/server.py for full schemas and examples.

Installation

Run with uvx (no install — recommended once published)

uvx japan-utils-mcp

From source (today)

git clone https://github.com/vivek081166/japan-utils-mcp.git
cd japan-utils-mcp
uv sync
uv run japan-utils-mcp

Configuration

Claude Desktop

Add to ~/Library/Application Support/Claude/claude_desktop_config.json (macOS) or %APPDATA%\Claude\claude_desktop_config.json (Windows):

{
  "mcpServers": {
    "japan-utils": {
      "command": "uvx",
      "args": ["japan-utils-mcp"]
    }
  }
}

Claude Code

claude mcp add japan-utils -- uvx japan-utils-mcp

Cursor / Cline / Continue

Same JSON snippet as Claude Desktop, in their respective MCP config files.

Examples

Once connected, ask your agent things like:

What year is 令和8年?era_to_western("令和8年")2026

What's the address for postal code 150-0001?lookup_postal_code("150-0001")東京都 渋谷区 神宮前

Convert 山田太郎 to romaji.kanji_to_romaji("山田太郎")yamada tarou

Is May 3rd 2026 a Japanese holiday?is_holiday("2026-05-03")憲法記念日 (Constitution Memorial Day)

List all Japanese holidays in 2026.list_holidays(2026) → 18 holidays with names and dates

Convert ヤマダタロウ to hiragana.convert_kana("ヤマダタロウ", "hiragana")やまだたろう

Normalize ABC123 to half-width.normalize_width("ABC123", "to_half")ABC123

Split 長谷川健太 into surname and given name.split_japanese_name("長谷川健太")長谷川 / 健太

Caveats

  • Romaji of personal names uses the most common reading — proper nouns with unusual readings will be wrong. This is a fundamental limitation of any kanji-to-romaji conversion without disambiguation context.
  • Postal code dataset ships via the posuto library, refreshed against Japan Post's monthly KEN_ALL. If you need ultra-fresh data, refresh posuto periodically.
  • Holidays covers national holidays (国民の祝日) only — not company-specific or regional observances.
  • Era conversion supports Meiji (明治) through Reiwa (令和). Earlier eras are not supported.

Development

git clone https://github.com/vivek081166/japan-utils-mcp.git
cd japan-utils-mcp
uv sync
uv run python -c "from japan_utils_mcp.server import era_to_western; print(era_to_western('令和8年'))"

License

MIT

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

japan_utils_mcp-0.1.0.tar.gz (8.8 kB view details)

Uploaded Source

Built Distribution

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

japan_utils_mcp-0.1.0-py3-none-any.whl (10.4 kB view details)

Uploaded Python 3

File details

Details for the file japan_utils_mcp-0.1.0.tar.gz.

File metadata

  • Download URL: japan_utils_mcp-0.1.0.tar.gz
  • Upload date:
  • Size: 8.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.8.2

File hashes

Hashes for japan_utils_mcp-0.1.0.tar.gz
Algorithm Hash digest
SHA256 73bae79d43516b1e4a4822f6358d41dc5443374350eb232f6354917b2b1fbc06
MD5 fbb01a02f04429b43be1344f7de3598a
BLAKE2b-256 72e9a43475e4cd3919262f24fab672d355bcc14515218e039706b0eab1a56489

See more details on using hashes here.

File details

Details for the file japan_utils_mcp-0.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for japan_utils_mcp-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 d0df15a8ad5e256f8ec3511e9e9d8a0d1782e28d94f66a1fdab8fbf701c8caf4
MD5 100205eeef14674348c16782e471f8df
BLAKE2b-256 d07d272bccbde766cea7d036a1a103ac49c424cba2e283f4bee09c043cac98d8

See more details on using hashes here.

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