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

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

文章目录

MCP 官网

MCP 官方文档中文版

官方 MCP 服务示例

Github

MCP 市场

在这里插入图片描述

https://mcpmarket.cn/

在这里插入图片描述

https://mcp.so/zh

在这里插入图片描述

简介

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 命令。
  • 高德 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"})asyncdefrun():asyncwith stdio_client(server_params)as(read, write):asyncwith 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 客户端

<!-- https://mvnrepository.com/artifact/io.modelcontextprotocol.sdk/mcp --><dependency><groupId>io.modelcontextprotocol.sdk</groupId><artifactId>mcp</artifactId><version>0.8.1</version></dependency>
// https://mvnrepository.com/artifact/io.modelcontextprotocol.sdk/mcp implementation("io.modelcontextprotocol.sdk:mcp:0.8.1") 
importio.modelcontextprotocol.client.McpClient;importio.modelcontextprotocol.client.McpSyncClient;importio.modelcontextprotocol.client.transport.ServerParameters;importio.modelcontextprotocol.client.transport.StdioClientTransport;importio.modelcontextprotocol.spec.McpSchema;importorg.junit.jupiter.api.Test;importjava.util.Map;publicclassJunitTest{@Testpublicvoidtest(){ServerParameters params =ServerParameters.builder("npx").args("-y","@amap/amap-maps-mcp-server").addEnvVar("AMAP_MAPS_API_KEY","xxxxx").build();StdioClientTransport transport =newStdioClientTransport(params);McpSyncClient client =McpClient.sync(transport).build(); client.initialize();McpSchema.ListToolsResult toolsList = client.listTools();System.out.println("工具列表:"+ toolsList);McpSchema.CallToolResult mapsWeather = client.callTool(newMcpSchema.CallToolRequest("maps_weather",Map.of("city","福州")));System.out.println("调用结果:"+ mapsWeather.content());}}
在这里插入图片描述

Read more

2026年2月14日-2026年2月炸场!手把手教你Docker一键部署Seedance 2.0双模型Web应用

2026年2月14日-2026年2月炸场!手把手教你Docker一键部署Seedance 2.0双模型Web应用

1.前言 在AI视频创作快速发展的今天,如何让AI更高效地帮助创作者生成高质量视频成为了大家关注的焦点。传统的视频制作流程不仅需要专业的拍摄设备和剪辑技巧,还需要花费大量时间在后期配音、口型对齐等繁琐工作上。对于普通创作者来说,想要制作一个高质量的短视频简直是难上加难。 好家伙,字节跳动豆包大模型 2.0 已正式发布!最新推出的 Seedance 2.0 视频生成模型在2026年2月火爆登场,这可是目前业界最强的AI视频生成模型之一。Seedance 2.0 最大的技术突破是实现了"原生音视频同步"——不再将音频作为后期添加,而是与视频同步生成。它支持四种模态输入(文字、图片、音频、视频),可同时参考多达9张图片、3段视频和3段音频进行生成,真正实现了"所想即所得"的视频创作自由!为了让大家更好地体验这个强大模型,我开发了一个基于即梦平台官方API的Web应用,支持双模型切换和Docker一键部署,架构简洁、使用方便。今天就带大家手把手教大家部署这个Seedance 2.0 Web应用,

By Ne0inhk
【2026最新】docker desktop for windows下载安装保姆级教程(附最新版安装包)

【2026最新】docker desktop for windows下载安装保姆级教程(附最新版安装包)

Docker Desktop for Windows(简称 Docker Desktop)是 Docker 公司在 Windows 上推出的桌面级图形安装包,把原本只能在 Linux 上跑的 Docker Engine、Docker Compose、Kubernetes 等一堆组件打包成一键安装程序。 Docker Desktop 的核心功能分为 3 块: 1. 单机容器生命周期管理,镜像、容器、网络、数据卷点点鼠标就能增删改; 2. Docker Compose 集成,写好 yaml 一键起整个微服务栈; 3. 自带 Kubernetes,勾选即可启动三节点最小 K8s,kubectl 已经配好路径,本地就能验证 Deployment、Service、ConfigMap

By Ne0inhk
Flutter 三方库 build_cli_annotations 的鸿蒙化适配指南 - 注解驱动的参数解析、自动化命令生成与高效开发工具链构建实战

Flutter 三方库 build_cli_annotations 的鸿蒙化适配指南 - 注解驱动的参数解析、自动化命令生成与高效开发工具链构建实战

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.ZEEKLOG.net Flutter 三方库 build_cli_annotations 的鸿蒙化适配指南 - 注解驱动的参数解析、自动化命令生成与高效开发工具链构建实战 前言 随着 Flutter for OpenHarmony 生态的日益庞大,开发者面临的不仅仅是 UI 适配,还有日益繁琐的项目管理和自动化脚本开发。如何快速编写一个高性能、强类型的命令行工具(CLI),用来自动化执行鸿蒙环境检测、包管理或是代码分发? 传统的 args 库虽然强大,但在处理复杂的多级子命令和参数校验时,代码会迅速变得难以维护。 build_cli_annotations 配合 build_cli 库,为我们提供了一种“代码即文档”的优雅方案。通过在 Dart 类上添加简单的注解,即可自动生成健壮的参数解析逻辑。本文将详细讲解这一技术在鸿蒙开发辅助脚本中的实战落地,助力开发者打造极致的自动化工具链。

By Ne0inhk
Flutter 组件 hydrated_mobx 的适配 鸿蒙Harmony 实战 - 驾驭自动化状态持久化、实现鸿蒙端 UI 状态在重启与多任务切换时的无缝恢复方案

Flutter 组件 hydrated_mobx 的适配 鸿蒙Harmony 实战 - 驾驭自动化状态持久化、实现鸿蒙端 UI 状态在重启与多任务切换时的无缝恢复方案

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.ZEEKLOG.net Flutter 组件 hydrated_mobx 的适配 鸿蒙Harmony 实战 - 驾驭自动化状态持久化、实现鸿蒙端 UI 状态在重启与多任务切换时的无缝恢复方案 前言 在鸿蒙(OpenHarmony)生态的深度体验中,用户对“断点续作”有着天然的期待。想象一下,用户正在你的鸿蒙平板 App 上填写一份复杂的表单,或者正在调整一个精密的编辑器参数,此时突然接到了一个紧急的鸿蒙系统推送流转,导致 App 被切入后台甚至因为内存压力被系统回收。 当用户再次点击图标回到 App 时,看到的是冷冰冰的初始化界面,还是瞬间恢复到上一次操作的完美现场? hydrated_mobx 为 Flutter 开发者提供了一套近乎魔法的状态持久化方案。它是对经典 MobX 的强力增强,通过简单的注解或扩展,就能让你的 Store 自动具备“

By Ne0inhk