mcp开发一个中医药材科普

实操

csharp 复制代码
uv init mcp-zhongyi   // 执行uv init mcp-weather命令初始化项目
cd mcp-zhongyi
uv venv   // 创建虚拟环境
.venv\Scripts\activate   // Linux下使用source .venv/bin/activate激活
uv add mcp
uv add requests
uv add openai
uv add zhipuai

代码

server.py

python 复制代码
import json
import requests
from typing import Any, List, Dict
from mcp.server.fastmcp import FastMCP
from openai import OpenAI

# 初始化MCP服务器
mcp = FastMCP("ZhongyiServer")
client = OpenAI(api_key="自己的deepseekkey", base_url="https://api.deepseek.com")

@mcp.tool()
async def get_yaocaiInfo(yaocai: str):
    """
    输入指定药材的名称,返回当前药材信息
    :param yaocai: 药材名称
    :return: json格式的药材信息
    """
    try:
        # 构建提示词
        prompt = f"""请以JSON格式返回关于"{yaocai}"的中药材信息,包含以下字段:
        1. name: 药材名称
        2. property: 药性(寒、热、温、凉)
        3. taste: 药味(酸、苦、甘、辛、咸)
        4. meridian: 归经
        5. function: 功效主治
        6. usage: 用法用量
        请确保返回的是合法的JSON格式。
        """
        
        # 调用DeepSeek API
        response = client.chat.completions.create(
            model="deepseek-chat",
            messages=[
                {"role": "system", "content": "你是一个专业的中医药专家,请提供准确的中药材信息。"},
                {"role": "user", "content": prompt}
            ],
            stream=False
        )
        
        # 获取回复并确保是JSON格式
        result = response.choices[0].message.content
        # 尝试解析JSON,如果失败则返回原始文本
        try:
            return json.loads(result)
        except json.JSONDecodeError:
            return {"error": "无法解析为JSON格式", "raw_content": result}
            
    except Exception as e:
        return {"error": f"获取药材信息出错:{str(e)}"}

if __name__ == "__main__":
    mcp.run(transport="sse")
python 复制代码
import json
import requests
from typing import Any, List, Dict
from mcp.server.fastmcp import FastMCP
from openai import OpenAI
from zhipuai import ZhipuAI

# 初始化MCP服务器
mcp = FastMCP("ZhongyiServer")
client = OpenAI(api_key="deepseek的apikey", base_url="https://api.deepseek.com")
clientZhiPu = ZhipuAI(api_key="智谱的apikey")
@mcp.tool()
async def get_yaocaiInfo(yaocai: str):
    """
    输入指定药材的名称,返回当前药材信息
    :param yaocai: 药材名称
    :return: json格式的药材信息
    """
    try:
        # 构建提示词
        prompt = f"""请以JSON格式返回关于"{yaocai}"的中药材信息,包含以下字段:
        1. name: 药材名称
        2. property: 药性(寒、热、温、凉)
        3. taste: 药味(酸、苦、甘、辛、咸)
        4. meridian: 归经
        5. function: 功效主治
        6. usage: 用法用量
        请确保返回的是合法的JSON格式。
        """
        
        # 调用DeepSeek API
        response = client.chat.completions.create(
            model="deepseek-chat",
            messages=[
                {"role": "system", "content": "你是一个专业的中医药专家,请提供准确的中药材信息。"},
                {"role": "user", "content": prompt}
            ],
            stream=False
        )
        
        # 获取回复并确保是JSON格式
        result = response.choices[0].message.content
        # 尝试解析JSON,如果失败则返回原始文本
        try:
            return json.loads(result)
        except json.JSONDecodeError:
            return {"error": "无法解析为JSON格式", "raw_content": result}
            
    except Exception as e:
        return {"error": f"获取药材信息出错:{str(e)}"}

# 添加一个工具,获取药材的图片
@mcp.tool()
async def get_yaocai_image(yaocai: str):
    """
    输入指定药材的名称,返回当前药材的图片
    :param yaocai: 药材名称
    :return: 药材的图片URL
    """
    try:
        # 构建提示词
        prompt = f"高清晰度的{yaocai}中药材实物图片,清晰展示其外观特征,包括颜色、形状和质地,白色背景,专业医药参考图"
        
        # 调用智谱AI的图像生成API
        response = clientZhiPu.images.generations(
            model="cogview-4-250304",  # 使用最新的图像生成模型
            prompt=prompt,
        )
        
        # 返回生成的图片URL
        return {
            "success": True,
            "image_url": response.data[0].url,
            "yaocai": yaocai
        }
            
    except Exception as e:
        return {
            "success": False,
            "error": f"获取药材图片出错:{str(e)}",
            "yaocai": yaocai
        }

if __name__ == "__main__":
    mcp.run(transport="sse")

相关内容

1.智谱apikey:www.bigmodel.cn/invite?icod...

2.deepseek的key:platform.deepseek.com/

注意

  1. 出现问题重新开关一下
相关推荐
羊羊小栈4 分钟前
农业病害知识管理系统(基于前后端Web开发)
前端·人工智能·毕业设计·大作业
武子康6 分钟前
调查研究-156 Vercel 全栈应用 前端零配置极速上线:Serverless + 边缘网络 + CI/CD 全栈实战
前端·网络·ci/cd·ai·云原生·serverless·vecel
码云骑士7 分钟前
Chrome插件开发实战指南:从零到上架
前端·chrome·microsoft
kiritomzzz11 分钟前
Vue 插槽(Slot)全解析:从 Vue2 到 Vue3 核心用法与案例
前端·javascript·vue.js
喵了几个咪12 分钟前
基于 Nuxt 4 的现代 Headless CMS 前端:架构深度解析与二次开发指南
前端·架构
weixin_427771611 小时前
css加载顺序导致本地和线上样式不一致
前端·css
漂流瓶jz8 小时前
Webpack如何实现万物皆可import?loader的使用/配置/手写实践
前端·javascript·webpack
ZC跨境爬虫8 小时前
跟着 MDN 学CSS day_41:显式轨道、隐式网格与区域命名放置
前端·javascript·css·ui·交互
修己xj9 小时前
告别手动存图!这款叫 Fatkun 的浏览器插件,简直是素材收集神器
前端