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 lookup —
150-0001→東京都 渋谷区 神宮前 - 🎌 National holiday calendar — is
2026-05-03a 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)
uvx japan-utils-mcp
That's it. uvx (from uv) handles install + run in one shot, isolated from your global Python.
From source
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
posutolibrary, refreshed against Japan Post's monthly KEN_ALL. If you need ultra-fresh data, refreshposutoperiodically. - 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
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file japan_utils_mcp-0.1.2.tar.gz.
File metadata
- Download URL: japan_utils_mcp-0.1.2.tar.gz
- Upload date:
- Size: 9.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
803e5d6fdab3439767466fc104e12163f8d86bc41d51b4812138d24e82681722
|
|
| MD5 |
e7e66ebd17fdc5b83facc5f740c3a51a
|
|
| BLAKE2b-256 |
f4ec965c42a9b2bd6e5fda562fb9dcd92aa0c1db1693d6afeb140d141c5d557f
|
Provenance
The following attestation bundles were made for japan_utils_mcp-0.1.2.tar.gz:
Publisher:
publish.yml on vivek081166/japan-utils-mcp
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
japan_utils_mcp-0.1.2.tar.gz -
Subject digest:
803e5d6fdab3439767466fc104e12163f8d86bc41d51b4812138d24e82681722 - Sigstore transparency entry: 1435606641
- Sigstore integration time:
-
Permalink:
vivek081166/japan-utils-mcp@5c7e7d49684e25a2851286de4c4ac901b0f927dc -
Branch / Tag:
refs/tags/v0.1.2 - Owner: https://github.com/vivek081166
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@5c7e7d49684e25a2851286de4c4ac901b0f927dc -
Trigger Event:
push
-
Statement type:
File details
Details for the file japan_utils_mcp-0.1.2-py3-none-any.whl.
File metadata
- Download URL: japan_utils_mcp-0.1.2-py3-none-any.whl
- Upload date:
- Size: 10.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a5c73945f69c7097bbe97223b4f080cda3ad3366ecba5b3827f4b650c1d51219
|
|
| MD5 |
5c18e2242b827d1d02c5163fdbdc0c7f
|
|
| BLAKE2b-256 |
763095296b08fc339469ec3e7ac029c75ba3bb21d7a63a6961ce5a953bbc14ba
|
Provenance
The following attestation bundles were made for japan_utils_mcp-0.1.2-py3-none-any.whl:
Publisher:
publish.yml on vivek081166/japan-utils-mcp
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
japan_utils_mcp-0.1.2-py3-none-any.whl -
Subject digest:
a5c73945f69c7097bbe97223b4f080cda3ad3366ecba5b3827f4b650c1d51219 - Sigstore transparency entry: 1435606715
- Sigstore integration time:
-
Permalink:
vivek081166/japan-utils-mcp@5c7e7d49684e25a2851286de4c4ac901b0f927dc -
Branch / Tag:
refs/tags/v0.1.2 - Owner: https://github.com/vivek081166
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@5c7e7d49684e25a2851286de4c4ac901b0f927dc -
Trigger Event:
push
-
Statement type: