究其原因,系调用MCP服务器中的工具时,其返回值格式为:

[TextContent(type='text', text='students_scores', annotations=None, meta=None)]

但调用DeepSeek API时,往往其格式要求为:

client = OpenAI(api_key="<DeepSeek API Key>", base_url="https://api.deepseek.com")
response = client.chat.completions.create(
    model="deepseek-chat",
    messages=[
        {"role": "system", "content": "You are a helpful assistant"},
        {"role": "user", "content": "Hello"},
    stream=False
print(response.choices[0].message.content)

即role&content
因此,需要对原始外部MCP服务器工具调用结果进行后处理以对齐Deepseek的输入要求。

修改后函数如下:

async def _call_mcp_tool_text(self, tool_name: str, tool_args: dict) -> str:
        根据工具名调用相应的服务器工具
        返回TextContent中的text即可 无需其他冗余信息(type、annotations、meta等)
        session = self.sessions.get(tool_name)
        if not session:
            return f"找不到服务器: {tool_name}"
        # 执行 MCP 工具
        result = await session.call_tool(tool_name, tool_args)
        # 重点!!!
        if resp.content and isinstance(resp.content, list) and len(resp.content) > 0:
            first_content = resp.content[0]
            if hasattr(first_content, 'text'):
                return first_content.text
        return "工具执行无输出"

再次执行MCP客户端程序,报错已解决:

The JsonDeserializer StringTypeAdapter failed to deserialize json object {} given the type class java.lang.String 解决方案如下: 1、新增String类型解析器StringDefault0Adapter //反序列化做如下处理: public String deserial...
问题原因: 登录成功后获取到的token只缓存到内存中,并没有序列化到本地;这种情况下内存回收token丢失后,访问接口就没有传递token才导致的422 Unprocessable Entity; The HyperText Transfer Protocol (HTTP) 422 Unprocessable Entity response status code indicates that ...
解决问题:com.fasterxml.jackson.databind.exc.InvalidFormatException: Cannot deserialize value of type `java.util.Date` from String "2019-10-08": not a valid representation (error: Failed to parse Date value '2019-10-08': Unparseable date: "2019-10-08")
🏆本文收录于《全栈Bug调优(实战版)》专栏,主要记录项目实战过程中所遇到的Bug或因后果及提供真实有效的解决方案,希望能够助你一臂之力,帮你早日登顶实现财富自由🚀;同,欢迎大家关注&&收藏&&订阅!持续更新中,up!up!up!! 备注:部分问题/疑难杂症搜集于互联网。
CSDN-Ada助手: 这篇博客内容很有深度,点云等比例归一化的技术确实在很多领域都有应用价值。希望作者能继续分享更多关于点云处理方面的知识和经验,让更多人受益。另外,如果能进一步探讨点云数据的特征提取、分类和分割等内容,将会使读者收获更多。加油!期待更多精彩的内容。 如何写出更高质量的博客,请看该博主的分享:https://blog.csdn.net/lmy_520/article/details/128686434?utm_source=csdn_ai_ada_blog_reply2 在Ubuntu 20.04 LTS环境下安装Docker CSDN-Ada助手: 恭喜你写了第一篇博客!安装Docker是一个很实用的技能,希望你可以继续分享更多关于Ubuntu环境下的技巧和经验。建议你可以考虑写一些关于Docker的基本操作或者实际应用的文章,让读者更好地了解和利用这个工具。加油!期待你的下一篇博客! 推荐【每天值得看】:https://bbs.csdn.net/forums/csdnnews?typeId=21804&utm_source=csdn_ai_ada_blog_reply1