jgrants-mcp-server
OfficialClick on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@jgrants-mcp-serversearch for renewable energy subsidies"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
Jグランツ MCP Server
デジタル庁が運用する補助金電子申請システム「Jグランツ」の公開APIをModel Context Protocol(MCP)サーバーとして実装。FastMCPフレームワークを使用し、LLMから自然言語で補助金検索・詳細取得が可能です。
特徴
リモート対応: Streamable-HTTP経由でリモート接続可能
高度な検索機能: キーワード、業種、従業員数、地域での絞り込み
統計分析: 補助金の統計情報を自動集計(締切期間別、金額規模別)
ファイルダウンロード: 募集要項や申請書類の自動ダウンロード・保存
添付資料アクセス: PDFなどの添付資料をMarkdown/BASE64形式で取得可能
LLM統合: 自然言語での補助金検索と詳細取得
ファイル変換: PDF、Word、Excel、ZIPなど多様な形式をMarkdownに変換
動的ツール検出: サーバーのツール変更を自動検出・適応
FastMCP: 最新のFastMCPフレームワーク (v2.12.2) を使用
Prompts/Resources: LLM向けのガイドとリソースを提供
動作確認環境
Claude Desktop: v0.7.10以上
Python: 3.11以上
FastMCP: 2.12.2以上
クイックスタート
前提条件
Python 3.11以上
pip (Pythonパッケージマネージャー)
環境セットアップ
# リポジトリのクローン
git clone https://github.com/digital-go-jp/jgrants-mcp-server.git
cd jgrants-mcp-server
# Python仮想環境の作成
python -m venv venv
# 仮想環境の有効化
# macOS/Linux:
source venv/bin/activate
# Windows:
# venv\Scripts\activate
# 依存パッケージのインストール
pip install -r requirements.txtUV を使った環境セットアップ(推奨)
UV は高速なPythonパッケージマネージャーです。より高速なインストールを実現します。
# リポジトリのクローン
git clone https://github.com/digital-go-jp/jgrants-mcp-server.git
cd jgrants-mcp-server
# UVで仮想環境を作成
uv venv
# 仮想環境の有効化
source .venv/bin/activate
# UVで依存パッケージをインストール
uv pip install -r requirements.txt環境変数(オプション)
必要に応じて以下の環境変数を設定できます:
環境変数 | デフォルト値 | 説明 |
|
| 添付ファイル保存ディレクトリ |
|
| JグランツAPIエンドポイント |
設定例:
export JGRANTS_FILES_DIR=/tmp/jgrants_filesサーバー起動
HTTPサーバーモード
# HTTPサーバーを起動(デフォルト: localhost:8000)
python -m jgrants_mcp_server.core
# ホストとポートを指定
python -m jgrants_mcp_server.core --host 0.0.0.0 --port 8080UV を使った起動
UV を使った場合、uv run で直接サーバーを起動できます:
# HTTPサーバーを起動(デフォルト: localhost:8000)
uv run python -m jgrants_mcp_server.core
# ホストとポートを指定
uv run python -m jgrants_mcp_server.core --host 0.0.0.0 --port 8484サーバー起動後、以下のエンドポイントが利用可能になります:
MCP エンドポイント:
http://localhost:8000/mcpもしくはhttp://127.0.0.1:8000/mcpトランスポート: Streamable-HTTP
Claude Desktop との連携
FastMCP CLI経由での接続(推奨)
Claude Desktop は stdio 接続のみサポートするため、FastMCP CLIをHTTPプロキシとして使用します。 この方法はResources、Prompts、Toolsのすべての機能をサポートします。
MCP Server を起動:
python -m jgrants_mcp_server.core --port 8000Claude Desktop 設定ファイルを編集:
macOS:
~/Library/Application Support/Claude/claude_desktop_config.jsonWindows:%APPDATA%\Claude\claude_desktop_config.jsonLinux:~/.config/Claude/claude_desktop_config.json{ "mcpServers": { "jgrants": { "command": "uvx", "args": [ "fastmcp", "run", "http://localhost:8000/mcp" ] } } }備考:
localhostでうまくいかない場合は 127.0.0.1 でお試しください
uvxはuvのコマンドラインツール実行機能です(pip install uvでインストール)uvxがインストールされていない場合は、fastmcpを直接使用することもできます:{ "mcpServers": { "jgrants": { "command": "fastmcp", "args": [ "run", "http://localhost:8000/mcp" ] } } }
Claude Desktop を再起動
Roo-Code との連携
Roo-Code は VS Code 拡張機能で、Streamable-HTTP 経由での MCP サーバー接続をサポートしています。
Streamable-HTTP接続の設定
リモートサーバーでMCPサーバーを起動:
uv run python -m jgrants_mcp_server.core --host 0.0.0.0 --port 8484Roo-Code の MCP 設定ファイルを編集:
VS Code で Roo-Code 拡張機能をインストール後、MCP 設定を編集します。
詳細な設定方法は Roo-Code MCP ドキュメント を参照してください。
{ "mcpServers": { "jgrants": { "type": "streamable-http", "url": "http://192.168.0.131:8484/mcp", "alwaysAllow": [ "search_subsidies", "get_subsidy_detail", "get_subsidy_overview", "get_file_content", "ping" ] } } }備考:
urlには実際のサーバーのIPアドレスとポート番号を指定してくださいalwaysAllowは自動的に実行を許可するツールの一覧です(省略可)リモート接続の場合、ファイアウォールやネットワーク設定を確認してください
VS Code を再起動
接続確認
Claude Desktop の場合: Claude Desktop を開き、新しい会話で以下のように質問してみてください:
補助金を検索できますか?Roo-Code の場合: VS Code で Roo-Code を開き、チャットで以下のように質問してみてください:
補助金を検索できますか?サーバーが正しく設定されていれば、利用可能なツールの一覧が表示されます。
Prompts と Resources
MCPサーバーは、LLMが効果的にツールを使用できるよう、プロンプトとリソースを提供します。
Prompts(動的ガイド)
subsidy_search_guide: 補助金検索のベストプラクティスと推奨検索パターンapi_usage_agreement: API利用規約と免責事項の確認
Resources(静的リファレンス)
jgrants://guidelines: MCPサーバー利用ガイドライン、API制限、トラブルシューティング
利用可能なツール
1. search_subsidies
補助金を検索します。キーワード、業種、地域、従業員数などで絞り込み可能。
パラメータ:
keyword(str): 検索キーワード(2文字以上必須)industry(str, optional): 業種target_area_search(str, optional): 対象地域target_number_of_employees(str, optional): 従業員数制約sort(str): ソート順(acceptance_end_datetime/acceptance_start_datetime/created_date)order(str): 昇順/降順(ASC/DESC)acceptance(int): 受付状態(0: 全て /1: 受付中のみ)
2. get_subsidy_detail
補助金の詳細情報を取得し、添付ファイルをローカルに保存します。
パラメータ:
subsidy_id(str): 補助金ID(18文字以下)
返却情報:
補助金の詳細情報(タイトル、補助上限額、補助率、受付期間など)
添付ファイルのfile:// URL(公募要領、概要資料、申請様式など)
ファイル保存先ディレクトリのパス
3. get_subsidy_overview
補助金の統計情報を取得します(締切期間別、金額規模別の集計)。
パラメータ:
output_format(str): 出力形式(json/csv)
4. get_file_content
保存済みの添付ファイルの内容を取得します。
パラメータ:
subsidy_id(str): 補助金IDfilename(str): ファイル名return_format(str): 返却形式(markdown/base64)
機能:
PDF、Word、Excel、PowerPoint、ZIPをMarkdownに自動変換
変換失敗時はBASE64形式で返却
5. ping
サーバーの疎通確認を行います。
開発とテスト
テスト実行
# テスト実行
pytest tests/test_core.pyデバッグ
# デバッグモードで起動
python -m jgrants_mcp_server.core --log-level DEBUGライセンス
MIT License - 詳細はLICENSEファイルを参照してください。
免責事項
本実装は、技術検証を目的としたサンプルコードです。以下の点にご留意ください:
本コードは現状のまま提供され、動作の安定性や継続的な保守を保証するものではありません
Jグランツサービスの検索性や動作の安定性を保証するものではありません
実際の利用にあたっては、JグランツAPIの利用規約 (https://www.jgrants-portal.go.jp/open-api) に準じてご利用ください
This server cannot be installed
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/digital-go-jp/jgrants-mcp-server'
If you have feedback or need assistance with the MCP directory API, please join our Discord server