Skip to main content
Glama

国金QMT-MCP

README.md11.4 kB
# QMT-MCP - 模块化量化交易助手 <div align="center"> ![Version](https://img.shields.io/badge/version-2.0.0-blue.svg) ![Python](https://img.shields.io/badge/python-3.8+-green.svg) ![License](https://img.shields.io/badge/license-MIT-yellow.svg) 一个基于FastMCP和XTQuant的模块化量化交易系统,提供智能策略生成、实时交易执行和回测分析功能。 </div> ## 🌟 项目特色 - **🔗 MCP协议集成**: 基于Model Context Protocol,与AI助手无缝连接 - **📈 智能策略生成**: 自动生成和优化量化交易策略 - **⚡ 实时交易执行**: 支持XTQuant/QMT实盘和模拟交易 - **🧠 模块化架构**: 清晰的代码结构,易于扩展和维护 - **📊 回测分析**: 完整的策略回测和绩效评估 - **🛡️ 风险控制**: 内置多层风险控制机制 ## 🎬 演示视频 > 📺 点击封面图或链接即可在 Bilibili 观看完整演示 > > https://www.bilibili.com/video/BV1SFGjz6EKN/?vd_source=26053b834f0ddd4f57b22169d74b6f78 <!-- 如果你准备了演示封面图,可以把下面这行的 docs/demo_cover.png 换成你的图片路径 --> [![演示视频封面](layout.png)](https://www.bilibili.com/video/BV1SFGjz6EKN/?vd_source=26053b834f0ddd4f57b22169d74b6f78) ## 🏗️ 系统架构 ``` 国金QMT-MCP/ ├── main.py # FastMCP服务器主入口 ├── config.json # 系统配置文件 ├── requirements.txt # 项目依赖 ├── src/ │ ├── config.py # 配置管理模块(支持环境变量) │ ├── tools/ # MCP工具实现 │ │ ├── trading_tool.py # 交易执行工具 │ │ └── qmt_tool.py # QMT策略工具 │ ├── strategies/ # 策略模块 │ │ ├── ma_strategy.py # 双均线策略 │ │ └── strategy_generator.py # 策略生成器 │ └── utils/ # 工具模块 │ ├── xtquant_client.py # XTQuant客户端 │ └── data_handler.py # 数据处理器 └── logs/ # 日志文件目录 ``` ## 🚀 快速开始 ### 环境要求 - **Python 3.8+** - **XTQuant/QMT客户端** (国金/迅投量化交易客户端) - **Windows系统** (XTQuant仅支持Windows) ### 安装步骤 1. **克隆项目** ```bash git clone <repository-url> cd Nondescript-MCP ``` 2. **安装依赖** ```bash pip install -r requirements.txt ``` 3. **配置环境** 创建 `.env` 文件并配置以下参数: ```env # ===================================================== # 国金QMT-MCP 环境配置文件 # 请根据你的实际环境修改下面的配置参数 # ===================================================== # 服务器配置 QUANTMCP_HOST=127.0.0.1 # MCP服务器监听地址,通常保持127.0.0.1 QUANTMCP_PORT=8000 # MCP服务器端口号,可根据需要修改 QUANTMCP_TRANSPORT=sse # 传输协议,保持sse即可 # XTQuant/QMT 交易客户端配置 # 重要:请修改为你的QMT安装路径和账户信息 QMT_PATH=你的QMT安装路径\userdata_mini # QMT客户端数据目录,如: D:\QMT\userdata_mini QMT_SESSION_ID=你的会话ID # QMT会话ID,整数,如: 12345 QMT_ACCOUNT_ID=你的交易账户ID # 你的模拟或实盘交易账户ID # QMT策略保存目录 QMT_STRATEGY_DIR=你的QMT策略目录\mpython # QMT策略文件保存目录,如: D:\QMT\mpython # 交易风险控制配置 MAX_ORDER_VALUE=100000.0 # 单笔订单最大金额(元),防止误操作大额下单 MAX_POSITION_VALUE=500000.0 # 单只股票最大持仓金额(元),控制单股风险 MIN_ORDER_QUANTITY=100 # 最小下单数量(股),通常为100的整数倍 MARKET_ORDER_SPREAD=0.1 # 市价单价差比例(0.1=10%),避免成交价偏离过大 # 策略默认参数配置 DEFAULT_SYMBOL=000001.SZ # 默认股票代码,用于测试和演示 DEFAULT_START_DATE=20240101 # 默认回测开始日期,格式YYYYMMDD DEFAULT_END_DATE=20241201 # 默认回测结束日期,格式YYYYMMDD DEFAULT_SHORT_PERIOD=5 # 默认短期均线天数 DEFAULT_LONG_PERIOD=20 # 默认长期均线天数 # 日志配置 LOG_LEVEL=INFO # 日志级别: DEBUG/INFO/WARNING/ERROR LOG_FILE=logs/quantmcp.log # 日志文件路径 ``` 4. **启动XTQuant客户端** - 打开国金QMT或迅投量化客户端 - 确保客户端已登录并连接 5. **启动国金QMT-MCP服务** ```bash python main.py ``` 服务启动后将在 `http://127.0.0.1:8000` 提供MCP服务。 ## 🔧 功能介绍 ### 交易工具 #### 下单功能 ```python # 通过MCP接口调用 place_order( symbol="000001.SZ", # 股票代码 quantity=100, # 买入股数 price=10.5, # 下单价格 direction="BUY" # 交易方向 ) ``` #### 撤单功能 ```python cancel_order(order_id="12345") # 撤销指定订单 ``` ### 策略生成 #### 双均线策略 ```python generate_ma_strategy( symbol="000001.SZ", # 目标股票 short_period=5, # 短期均线 long_period=20, # 长期均线 strategy_name="my_ma" # 策略名称 ) ``` #### 自定义策略 ```python save_qmt_strategy( strategy_name="custom_strategy", code=""" def init(context): # 策略初始化 pass def handle_bar(context, bar_dict): # 策略执行逻辑 pass """ ) ``` ## 📊 策略回测 系统提供完整的策略回测功能,包括: - **收益指标**: 总收益率、年化收益率、夏普比率 - **风险指标**: 最大回撤、波动率、VaR - **交易统计**: 交易次数、胜率、平均盈亏 - **绩效评估**: 策略评级和优化建议 ### 回测报告示例 ``` [OK] 双均线策略生成成功! [DATA] 股票信息: 000001.SZ [DATE] 数据期间: 20240101 至 20241201 [CHART] 数据条数: 242 条 [DATA] 交易天数: 242 天 [TARGET] 双均线策略参数: * 短期均线: 5日 * 长期均线: 20日 [CHART] 策略表现: * 总收益率: 15.23% * 年化收益率: 18.45% * 最大回撤: -8.67% * 年化波动率: 22.15% * 夏普比率: 0.845 * 交易次数: 24 * 胜率: 58.33% [TIP] 策略评价: [OK] 年化收益良好,超过15% [OK] 风险控制优秀,最大回撤小于10% [WARNING] 夏普比率一般,收益风险比有待提升 [OK] 胜率良好,超过50% ``` ## 🛡️ 风险控制 系统内置多层风险控制机制: ### 交易层面 - 单笔订单最大金额限制 - 单标的最大持仓限制 - 最小下单数量控制 - 市价单价差保护 ### 策略层面 - 最大回撤限制 - 最小夏普比率要求 - 杠杆率控制 - 止损比例设置 ### 系统层面 - 交易状态控制 - 连接状态监控 - 异常处理机制 - 日志记录追踪 ## 🔌 MCP集成 国金QMT-MCP完全兼容Model Context Protocol,可以与支持MCP的AI助手集成: ### 首选:SSE 直连配置(推荐) 如果你只需要**直接连接**到已经启动的国金QMT-MCP服务器,最简洁可靠的方式就是使用 **SSE(Server-Sent Events) 直连**。 ```json { "mcpServers": { "qmt-mcp": { "type": "sse", "url": "http://127.0.0.1:8000/sse", "timeout": 60, "autoApprove": [] } } } ``` > 📌 **为何推荐 SSE?** > - 🛠️ **零依赖**:客户端无需再执行 Python/Node 等命令。 > - ⚡ **即开即用**:服务器启动后即可被任何支持MCP的应用发现。 > - 🪶 **配置最少**:仅需 `type` 与 `url` 两个关键字段。 > - 🌐 **远程友好**:修改 `url` 即可在局域网/云服务器访问。 下面展示不同工具 (Claude Desktop / VS Code Cline / Cursor) 的完整配置示例,如果需要自动拉起服务器也可使用 `command/args` 模式。 ### Claude Desktop集成 在Claude Desktop的配置文件中添加: ```json { "mcpServers": { "quantmcp": { "command": "python", "args": ["path/to/Nondescript-MCP/main.py"], "env": { "QMT_PATH": "你的QMT安装路径\\userdata_mini" } } } } ``` ### 可用工具 - `place_order`: 执行股票交易 - `cancel_order`: 撤销订单 - `save_qmt_strategy`: 保存自定义策略 - `generate_ma_strategy`: 生成双均线策略 ## 📋 配置说明 ### 核心配置项 | 配置项 | 说明 | 默认值 | |--------|------|--------| | QMT_PATH | QMT客户端安装路径 | 你的QMT安装路径\userdata_mini | | QMT_SESSION_ID | QMT会话ID | 你的会话ID | | QMT_ACCOUNT_ID | 交易账户ID | 你的交易账户ID | | MAX_ORDER_VALUE | 单笔订单最大金额 | 100000.0 | | MAX_POSITION_VALUE | 单标的最大持仓 | 500000.0 | ### 策略配置项 | 配置项 | 说明 | 默认值 | |--------|------|--------| | DEFAULT_SYMBOL | 默认股票代码 | 000001.SZ | | DEFAULT_SHORT_PERIOD | 默认短期均线 | 5 | | DEFAULT_LONG_PERIOD | 默认长期均线 | 20 | ## 🧪 开发指南 ### 添加新策略 1. 在 `src/strategies/` 目录下创建策略模块 2. 实现策略类,包含信号计算和回测方法 3. 在 `strategy_generator.py` 中注册新策略 4. 更新配置文件添加策略参数 ### 添加新工具 1. 在 `src/tools/` 目录下创建工具模块 2. 实现工具类和相关方法 3. 在 `main.py` 中使用 `@mcp.tool()` 装饰器注册 4. 更新 `__init__.py` 文件导出新工具 ### 测试 ```bash # 运行测试 pytest tests/ # 代码格式化 black src/ # 代码检查 flake8 src/ ``` ## 📚 API文档 ### place_order(symbol, quantity, price, direction) 执行股票交易订单 **参数:** - `symbol` (str): 股票代码,如 "000001.SZ" - `quantity` (int): 交易数量,必须是100的整数倍 - `price` (float): 下单价格 - `direction` (str): 交易方向,"BUY" 或 "SELL" **返回:** - `str`: 下单结果信息 ### generate_ma_strategy(symbol, short_period, long_period, strategy_name) 生成双均线策略 **参数:** - `symbol` (str): 目标股票代码 - `short_period` (int): 短期均线周期 - `long_period` (int): 长期均线周期 - `strategy_name` (str, optional): 策略名称 **返回:** - `str`: 策略生成和回测结果 ## 🔍 常见问题 ### Q: XTQuant连接失败怎么办? A: 确保QMT客户端已启动并登录,检查 `QMT_PATH` 配置是否正确。 ### Q: 如何修改风险控制参数? A: 在 `.env` 文件中修改 `MAX_ORDER_VALUE`、`MAX_POSITION_VALUE` 等参数。 ### Q: 策略回测数据不准确? A: 检查数据日期范围,确保XTQuant有相应的历史数据权限。 ### Q: 如何添加新的技术指标? A: 在 `src/strategies/` 目录下创建新的策略模块,参考 `ma_strategy.py` 的实现。 ## 📄 许可证 本项目采用 MIT 许可证 - 详见 [LICENSE](LICENSE) 文件 ## 🤝 贡献 欢迎提交Issue和Pull Request来改进项目! ## 📞 联系方式 - 项目地址: https://github.com/guangxiangdebizi/QMT-MCP - 问题反馈: https://github.com/guangxiangdebizi/QMT-MCP/issues - 文档: https://github.com/guangxiangdebizi/QMT-MCP/wiki - 邮箱: guangxiangdebizi@gmail.com - LinkedIn: https://www.linkedin.com/in/%E6%98%9F%E5%AE%87-%E9%99%88-b5b3b0313/ --- <div align="center"> **🌟 如果这个项目对你有帮助,请给个Star支持一下! 🌟** </div>

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/guangxiangdebizi/QMT-MCP'

If you have feedback or need assistance with the MCP directory API, please join our Discord server