MCP之PYTHON对接大模型遇到的坑

后面会分享个JAVA版本的

PYTHON环境准备

python的本地安装就跳过了,IDE用自己的使用的就可以了

安装UV

复制代码
pip install uv

设置您的环境

bash 复制代码
# 创建项目目录
uv init mcp-client
cd mcp-client
# 创建虚拟环境
uv venv
# 激活虚拟环境
# 在 Windows 上:
.venv\Scripts\activate
# 在 Unix 或 MacOS 上:
source .venv/bin/activate
# 安装所需的包
uv add mcp anthropic python-dotenv
# 删除样板文件
rm hello.py
# 创建我们的主文件
touch client.py

设置您的 API 密钥

需要到使用模型的官网找到对应的密钥。

创建一个 .env 文件来存储它:

ini 复制代码
创建 .env 文件
touch .env
将您的密钥添加到 .env 文件中:
OPENAI_API_KEY=API-KEY
BASE_URL=https://dashscope.aliyuncs.com/compatible-mode/v1
MODEL=qwq-32b

uv的一些命令

官方文档中给的流程图感觉不是太清晰,然后我找了一个流程图

这个流程图我再次发一下,因为对比上篇java版本的(MCP对接Spring AI Alibaba遇到的坑),python更能体会每步的流程(感觉java的封装的比较深吧

网上经常说的MCP非常消耗TOKEN(个人觉得根据上面流程图

  • 要识别调用的工具链,转换为合适的参数
  • 因为MCP是客户本地的服务,需要给本地服务传递调用指令,还需要的到MCP-SERVER的执行结果(一句话链路回合多了)。

网上demo遇到的常见问题

  • 出错的地方在调用本地MCP-SERVER的时候报错
  • 出错的地方在调用本地MCP-SERVER完成后把结果反馈给大模型的时候报错

最常见的报错1:

报错:ModuleNotFoundError: No module named 'mcp'

这问题的报错原因:因为工具加载的时候是通过命令的方式启动加载的。但是你参考的有些地方却写的是python(python环境没有安装mcp的包),改成uv就可以了等于切换了环境。

ini 复制代码
# 根据脚本类型选择执行命令
    command = "uv" if is_python else "node"
    server_params = StdioServerParameters(
        command=command,
        args=["run", server_script_path],
        env=None
    )

最常见的报错2:

报错:在大模型返回信息-》调用本地server-》本地信息在上传个大模型(报错)

css 复制代码
⚠️ 发生错误: Error code: 400 - {'error': {'code': 'invalid_parameter_error', 'param': None, 'message': '<400> InternalError.Algo.InvalidParameter: messages with role "tool" must be a response to a preceeding message with "tool_calls".', 'type': 'invalid_request_error'}, 'id': 'chatcmpl-5801dfcb-208a-913e-930c-b830159810af', 'request_id': '5801dfcb-208a-913e-930c-b830159810af'}

这问题的报错原因:role的问题,把工具调用后返回给大模型做处理的时候,role:tool改为role:funcion就可以了。

bash 复制代码
#原有的信息再拼接个工具调用内容返回给大模型的参数组装
messages.append({
                "role": "function",
                "content": result_content,
                "tool_call_id": tool['id'],
                #"tool_calls": tool_calls
            })
相关推荐
乾坤瞬间5 小时前
【Java后端进行ai coding实践系列二】记住规范,记住内容,如何使用iflow进行上下文管理
java·开发语言·ai编程
bluetata7 小时前
Rokid AR眼镜开发入门:构建智能演讲提词器Android应用
android·人工智能·云计算·ar·ai编程
Patrick_Wilson8 小时前
AI 时代下的工程师核心竞争力思考
人工智能·ai编程·求职
.NET修仙日记8 小时前
Visual Studio 演进之路:从集成套件到AI驱动的开发平台
ide·编辑器·ai编程·visual studio·1024程序员节
大模型真好玩13 小时前
LangGraph实战项目:从零手搓DeepResearch(四)——OpenDeepResearch源码解析与本地部署
人工智能·agent·mcp
stark张宇15 小时前
高手项目:手把手带你构建AI办公应用,赋能企业数字化
ai编程·laravel·swoole
昭昭日月明16 小时前
🚀 告别手动调试,Chrome DevTools MCP 推荐
ai编程·mcp
紫穹16 小时前
010.ConversationChain 一键记忆链:字幕版实现与暴躁助手实战
后端·ai编程
飞哥数智坊17 小时前
打造我的 AI 开发团队(四):在 Cursor 里跑通 bmad
人工智能·ai编程