news 2026/6/21 10:33:02

不过ai 直接调用mcp方法 ClientSession, StdioServerParameters

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
不过ai 直接调用mcp方法 ClientSession, StdioServerParameters

代码cline写的

MCP客户端示例 ================================================== 可用的MCP服务器: - blender-tool: Blender 工具服务器 - ue-tool: Unreal Engine工具服务器 - browser-tool: 浏览器工具服务器 - computer-tool: 计算机 控制工具服务器 - ocr-tool: OCR工具服务 器 - likefavarite-tools: 点赞收藏检测工具服务器 示例1:列出Blender工具 Blender工具服务器 (blender-tool) 可用工具: - activate_blender_window: 激活Blender窗口(精 确匹配窗口标题),如果没有运行则启动Blender - fix_model: 执行 Fix Model 操作 - import_pmx_file: 导入PMX文件 - delete_all_objects: 删除所有对象和集合 - parent_object_to_armature: 将选中的对象设置为骨骼绑定父级 - set_blender_scale_settings: 设置Blender场景的单 位比例和当前对象的缩放 - delete_objects_by_name: 删除名称包含指定模式的物体 Args: name_pattern (str): 要匹配的名称模式 - clear_parent_keep_transform: 清除选中对象的父级关系,但保持变换(位置、旋转、缩放) - apply_armature_pose: 切换到姿态模式并应用选中的骨架 - scale_objects_to_match_height: 将所有不包含"ObjectName"的物体缩放到与ObjectName物体相同的高度(三轴等比例缩放) - import_psk_file: 导入PSK文件(外部选择文件路径) - parent_object_to_bone: 将选中的对象设置为骨骼父级 - add_data_transfer_modifier: 添加数据传输修改器并配置顶点组权重传输 示例2:调用Blender的activate_blender_window工具 调用 blender-tool 的 activate_blender_window 工 具结果: false 示例3:调用computer工具 的click_mouse工具(示例 坐标) 调用 computer-tool 的 click_mouse 工具结果: 点击成功: (100, 100), 类型: left, 次数: 1 示例4:调用OCR工具的find_text_coordinates工具 调用 ocr-tool 的 find_text_coordinates 工具结果 : { "text": "'示例文本", "target_text": "示例文本", "center_x": 429, "center_y": 694 } 演示完成。
#!/usr/bin/env python3 """ MCP客户端示例脚本 - 调用MCP服务器中的工具 此脚本演示如何使用mcp库连接到已配置的MCP服务器并调用其工具。 支持的服务器包括:blender-tool, ue-tool, browser-tool, computer-tool, ocr-tool, likefavarite-tools """ import asyncio import sys import os # 导入mcp客户端相关模块 from mcp import ClientSession, StdioServerParameters from mcp.client.stdio import stdio_client class MCPClient: """MCP客户端类,用于连接和调用MCP服务器工具""" def __init__(self): self.servers = { 'blender-tool': { 'command': sys.executable, 'args': [os.path.join('my_python_server', 'blender_cline', 'blender_api_tool.py')], 'description': 'Blender工具服务器' }, 'ue-tool': { 'command': sys.executable, 'args': [os.path.join('my_python_server', 'ue_cline', 'ue_api_tool.py')], 'description': 'Unreal Engine工具服务器' }, 'browser-tool': { 'command': sys.executable, 'args': [os.path.join('my_python_server', 'browser_cline', 'browser_api_tool.py')], 'description': '浏览器工具服务器' }, 'computer-tool': { 'command': sys.executable, 'args': [os.path.join('my_python_server', 'computer_cline', 'computer_api_tool.py')], 'description': '计算机控制工具服务器' }, 'ocr-tool': { 'command': sys.executable, 'args': [os.path.join('my_python_server', 'ocr', 'ocr.py')], 'description': 'OCR工具服务器' }, 'likefavarite-tools': { 'command': sys.executable, 'args': [os.path.join('my_python_server', 'yolo', 'detect_like_favorite.py')], 'description': '点赞收藏检测工具服务器' } } async def list_tools(self, server_name): """列出指定服务器的所有可用工具""" if server_name not in self.servers: print(f"错误:未知的服务器 '{server_name}'") return [] server_config = self.servers[server_name] server_params = StdioServerParameters( command=server_config['command'], args=server_config['args'], env=None ) try: async with stdio_client(server_params) as (read, write): async with ClientSession(read, write) as session: # 初始化会话 await session.initialize() # 获取可用工具 tools_result = await session.list_tools() tools = tools_result.tools print(f"\n{server_config['description']} ({server_name}) 可用工具:") for tool in tools: print(f"- {tool.name}: {tool.description}") return tools except Exception as e: print(f"连接到 {server_name} 时出错: {e}") return [] async def call_tool(self, server_name, tool_name, arguments=None): """调用指定服务器的指定工具""" if server_name not in self.servers: print(f"错误:未知的服务器 '{server_name}'") return None if arguments is None: arguments = {} server_config = self.servers[server_name] server_params = StdioServerParameters( command=server_config['command'], args=server_config['args'], env=None ) try: async with stdio_client(server_params) as (read, write): async with ClientSession(read, write) as session: # 初始化会话 await session.initialize() # 调用工具 result = await session.call_tool(tool_name, arguments) print(f"\n调用 {server_name} 的 {tool_name} 工具结果:") for content in result.content: if hasattr(content, 'text'): print(content.text) elif hasattr(content, 'type'): print(f"[{content.type}]: {content}") return result except Exception as e: print(f"调用 {server_name} 的 {tool_name} 时出错: {e}") return None async def main(): """主函数,演示如何使用MCP客户端""" client = MCPClient() print("MCP客户端示例") print("=" * 50) # 选择要使用的服务器 print("\n可用的MCP服务器:") for name, config in client.servers.items(): print(f"- {name}: {config['description']}") # 示例1:列出Blender工具 print("\n示例1:列出Blender工具") await client.list_tools('blender-tool') # 示例2:调用一个简单的工具(如果可用) print("\n示例2:调用Blender的activate_blender_window工具") await client.call_tool('blender-tool', 'activate_blender_window') # 示例3:调用computer工具的click_mouse(需要坐标参数) print("\n示例3:调用computer工具的click_mouse工具(示例坐标)") await client.call_tool('computer-tool', 'click_mouse', { 'x': '100', 'y': '100', 'click_type': 'left', 'clicks': '1' }) # 示例4:调用OCR工具 print("\n示例4:调用OCR工具的find_text_coordinates工具") await client.call_tool('ocr-tool', 'find_text_coordinates', { 'text_to_find': '示例文本' }) print("\n演示完成。") if __name__ == "__main__": # 运行异步主函数 asyncio.run(main())
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/18 12:01:23

《把脉行业与技术趋势》-67-与民族复兴同频,与技术革命共震,与行业爆发同步,与优秀组织同行,与自己认知迭代,那么,你今日的平凡耕耘,必将成为明日非凡的回响。

1. 与民族复兴同频→ 锚定大势,不逆流而动 民族复兴不是抽象口号,而是具体表现为:科技自立自强(芯片、AI、航天)共同富裕导向(普惠医疗、教育、乡村振兴)绿色低碳转型(新能源、碳管理…

作者头像 李华
网站建设 2026/6/9 15:16:11

数据驱动创新协作:知识图谱赋能科技成果转化新范式

科易网AI技术转移与科技成果转化研究院 在科技创新日益成为国家核心竞争力的今天,如何打破信息壁垒、优化资源配置、加速成果转化,成为行业面临的关键课题。技术转移领域作为连接科研与产业的桥梁,正经历一场由数据驱动的新变革。传统的成果…

作者头像 李华
网站建设 2026/6/20 18:43:20

数据中心锂电化潮起:为什么说霍尔传感器决定了UPS的“生死线”?

时代向前发展,AI已经已经影响各行各业,就电池行业而言,随着数据中心规模不断扩大,电价波动加剧,碳指标收紧以及园区微电网的发展,数据中心正经历一场结构性转变--锂电化。市面常用的铅酸电池因体积大、寿命…

作者头像 李华
网站建设 2026/6/15 18:10:33

企业AI落地,“范例”比“功能”更能解决“不会用”的问题

很多企业选了AI框架后,都会遇到一个共性问题: 框架功能很全,但不知道怎么和自己的业务结合——比如知道能做智能问数,却不清楚怎么对接自己的业务数据库;知道支持多模态,却不知道怎么落地到视频剪辑、数字人…

作者头像 李华
网站建设 2026/6/20 22:11:33

2026年AI智能硬件集成开发行业十大技术突破白皮书

2026年AI智能硬件集成开发:十大服务商深度解析与选择策略在人工智能技术快速发展的今天,AI智能硬件集成开发已成为企业数字化转型的重要支撑。然而,如何从众多服务商中挑选出最适合的合作伙伴?本文将通过多维度分析,推…

作者头像 李华
网站建设 2026/6/12 20:16:32

开源活动报名表单系统源码,私有化部署,安全可控的二次开发利器

温馨提示:文末有资源获取方式对于追求数据安全、希望拥有高度自主权并具备技术开发能力的企业与团队来说,选择一款开源、可私有化部署的系统是至关重要的。本文将详细介绍一款功能完备的活动报名与自定义表单系统源码,它不仅能满足您当前的需…

作者头像 李华