跳到主要内容
极客日志极客日志面向AI+效率的开发者社区
首页博客GitHub 精选镜像工具UI配色美学隐私政策关于联系
搜索内容 / 工具 / 仓库 / 镜像...⌘K搜索
注册
博客列表
PythonNode.jsAIjava

Python 实现 MCP 客户端调用高德地图天气查询示例

综述由AI生成MCP 是一种开放协议,用于标准化应用程序向大语言模型提供上下文的方式。该方案演示了如何使用 Python SDK 连接高德地图 MCP 服务器,通过调用 maps_weather 工具查询指定城市的天气信息。同时提供了 Java SDK 的集成示例及依赖配置,展示了 MCP 客户端与服务器的交互流程,包括初始化、工具列表获取及工具调用过程。

林间仙子发布于 2026/2/5更新于 2026/5/258.9K 浏览
Python 实现 MCP 客户端调用高德地图天气查询示例

简介

MCP 是一种开放协议,它标准化了应用程序向 LLM 提供上下文的方式。可以将 MCP 视为 AI 应用程序的 USB-C 端口。正如 USB-C 提供了一种将设备连接到各种外围设备和配件的标准化方式一样,MCP 提供了一种将 AI 模型连接到不同数据源和工具的标准化方式。

架构

  • MCP 主机:希望通过 MCP 访问数据的程序,例如 Claude Desktop、IDE 或 AI 工具
  • MCP 客户端:与服务器保持 1:1 连接的协议客户端
  • MCP 服务器:轻量级程序,每个程序都通过标准化模型上下文协议公开特定功能
  • 本地数据源:MCP 服务器可以安全访问的您的计算机文件、数据库和服务
  • 远程服务:MCP 服务器可通过互联网(例如通过 API)连接到的外部系统

高德地图 MCP 客户端示例

环境准备

Node 版本 >= 18.20.4,版本太低无法执行 npx 命令。 下载地址:https://nodejs.org/zh-cn/download

高德地图 MCP 服务 tools 列表

高德地图文档(申请 AMAP_MAPS_API_KEY):https://lbs.amap.com/api/mcp-server/summary

{"tools":[{"description":"根据城市名称或者标准 adcode 查询指定城市的天气","inputSchema":{"properties":{"city":{"type":"string","description":"城市名称或者 adcode"}},"required":["city"],"type":"object"},"name":"maps_weather"},{"description":"查询关键词搜或者周边搜获取到的 POI ID 的详细信息","inputSchema":{"properties":{"id":{"type":"string","description":"关键词搜或者周边搜获取到的 POI ID"}},"required":["id"],"type":"object"},"name":"maps_search_detail"}]}

Python SDK 客户端

安装依赖:

pip install mcp

代码示例:

import asyncio
from mcp import ClientSession, StdioServerParameters, types
from mcp.client.stdio import stdio_client

server_params = StdioServerParameters(
    command="npx",
    args=["-y", "@amap/amap-maps-mcp-server"],
    env={"AMAP_MAPS_API_KEY": "xxxxx"}
)

async def run():
    async with stdio_client(server_params) as (read, write):
        async with ClientSession(read, write) as session:
            await session.initialize()
            tools = await session.list_tools()
            print("工具列表:", tools)
            result = await session.call_tool("maps_weather", arguments={"city": "福州"})
            print("调用结果:", result)

if __name__ == "__main__":
    asyncio.run(run())

Java SDK 客户端

0.7 版本迁移 0.8 版指南:https://github.com/modelcontextprotocol/java-sdk/blob/main/migration-0.8.0.md

Maven 依赖:

<!-- https://mvnrepository.com/artifact/io.modelcontextprotocol.sdk/mcp -->
<dependency>
    <groupId>io.modelcontextprotocol.sdk</groupId>
    <artifactId>mcp</artifactId>
    <version>0.8.1</version>
</dependency>

Gradle 依赖:

implementation("io.modelcontextprotocol.sdk:mcp:0.8.1")

代码示例:

import io.modelcontextprotocol.client.McpClient;
import io.modelcontextprotocol.client.McpSyncClient;
import io.modelcontextprotocol.client.transport.ServerParameters;
import io.modelcontextprotocol.client.transport.StdioClientTransport;
import io.modelcontextprotocol.spec.McpSchema;
import org.junit.jupiter.api.Test;
import java.util.Map;

public class JunitTest {
    @Test
    public void test() {
        ServerParameters params = ServerParameters.builder("npx")
                .args("-y", "@amap/amap-maps-mcp-server")
                .addEnvVar("AMAP_MAPS_API_KEY", "xxxxx")
                .build();
        StdioClientTransport transport = new StdioClientTransport(params);
        McpSyncClient client = McpClient.sync(transport).build();
        client.initialize();
        McpSchema.ListToolsResult toolsList = client.listTools();
        System.out.println("工具列表:" + toolsList);
        McpSchema.CallToolResult mapsWeather = client.callTool(new McpSchema.CallToolRequest("maps_weather", Map.of("city", "福州")));
        System.out.println("调用结果:" + mapsWeather.content());
    }
}

参考资料

  • MCP 官网:https://modelcontextprotocol.io/introduction
  • 官方 MCP 服务示例:https://github.com/modelcontextprotocol/servers
  • Python SDK:https://github.com/modelcontextprotocol/python-sdk
  • Java SDK:https://github.com/modelcontextprotocol/java-sdk
  • TypeScript SDK:https://github.com/modelcontextprotocol/typescript-sdk

目录

  1. 简介
  2. 架构
  3. 高德地图 MCP 客户端示例
  4. 环境准备
  5. 高德地图 MCP 服务 tools 列表
  6. Python SDK 客户端
  7. Java SDK 客户端
  8. 参考资料
  • 💰 8折买阿里云服务器限时8折了解详情
  • Magick API 一键接入全球大模型注册送1000万token查看
  • 🤖 一键搭建Deepseek满血版了解详情
  • 一键打造专属AI 智能体了解详情
极客日志微信公众号二维码

微信扫一扫,关注极客日志

微信公众号「极客日志V2」,在微信中扫描左侧二维码关注。展示文案:极客日志V2 zeeklog

更多推荐文章

查看全部
  • Linux 网络编程:基于 C++ 实现 JSON 与 HTTP Web 服务器
  • 大学生论文写作:AI 工具全流程实战指南
  • OpenClaw ACP 协议深度解析:IDE 直接驱动 AI Agent
  • OpenClaw 安装配置:Minimax/DeepSeek 模型与飞书机器人接入
  • 渗透测试之电脑(PC)端小程序抓包教程
  • 将 AI 小助手接入企业微信:基于回调接口的群聊机器人实现
  • Seedance 2.0 成本诊断插件:内置实时 FLOPs/USD 热力图与优化策略
  • Oracle 迁移工程实践:落地实操与成本分析
  • Java 面向对象编程核心:包管理、封装设计与代码块使用
  • 大语言模型 (LLM) 入门学习路线图
  • AIGC电商实战:OpenCSG公益课厘清“品牌叙事”与“商品素材”的AI应用边界
  • 前端动画库实战:CSS、Framer Motion 与 GSAP 选型指南
  • AI 编程工具深度对比:Cursor、Copilot、Trae 与 Claude Code
  • MySQL 数据库约束与设计指南
  • 二叉树递归遍历与剪枝算法详解
  • 无人机视觉语言导航入门:核心概念与技术挑战
  • MCP 协议集成实战:以 browser-tools-mcp 为例
  • Apache IoTDB 数据删除:从单点精准清除到企业级生命周期管理
  • 语义化 AI 驱动器:提示词工程的技术演进与未来
  • AI 智能体开发纲要:整合多亚专科医学知识(2025 版)

相关免费在线工具

  • RSA密钥对生成器

    生成新的随机RSA私钥和公钥pem证书。 在线工具,RSA密钥对生成器在线工具,online

  • Keycode 信息

    查找任何按下的键的javascript键代码、代码、位置和修饰符。 在线工具,Keycode 信息在线工具,online

  • Escape 与 Native 编解码

    JavaScript 字符串转义/反转义;Java 风格 \uXXXX(Native2Ascii)编码与解码。 在线工具,Escape 与 Native 编解码在线工具,online

  • Mermaid 预览与可视化编辑

    基于 Mermaid.js 实时预览流程图、时序图等图表,支持源码编辑与即时渲染。 在线工具,Mermaid 预览与可视化编辑在线工具,online

  • JavaScript / HTML 格式化

    使用 Prettier 在浏览器内格式化 JavaScript 或 HTML 片段。 在线工具,JavaScript / HTML 格式化在线工具,online

  • JavaScript 压缩与混淆

    Terser 压缩、变量名混淆,或 javascript-obfuscator 高强度混淆(体积会增大)。 在线工具,JavaScript 压缩与混淆在线工具,online