用 OpenClaw + 飞书 Agent 打造 AI 自主模拟炒股系统:从零到实盘全记录

news2026/3/18 9:12:52
作者海风 日期2026年3月17日本文记录了我用 OpenClaw 2026.3.8 搭建 AI 自主模拟炒股系统的完整过程。trader Agent 拥有 5 万元虚拟资金每天自主选股、自主决策买卖、自主管理仓位——完全不需要人类干预交易决策。一、背景为什么让 AI Agent 炒股2026 年AI Agent 已经从聊天机器人进化到能自主执行复杂工作流的智能体。我一直在想如果给一个 AI Agent 一笔钱让它在 A 股市场上自主投资它能做得怎么样这不是一个理论问题——借助OpenClaw一个开源 AI Agent 框架我们真的可以搭建这样一个系统。于是在某个周二的傍晚我开始了这个实验。我的目标给 trader Agent5 万元虚拟资金让它完全自主选股、买卖、管理仓位严格遵守 A 股交易规则T1、涨跌停、手续费每天自动运行我只看结果验证 AI Agent 的投资决策能力二、技术栈一览组件技术选型用途Agent 框架OpenClaw 2026.3.8多 Agent 协作平台前端交互飞书 Agent「多多助理」人机交互界面接收 Agent 报告大模型Kimi 2.5Agent 的大脑负责推理决策行情数据TuShare 高级 APIA 股日线、基本面、交易日历信息搜索SearXNG Jina Reader搜索财经新闻辅助决策金融数据 SkillTuShare 官方 Skillwaditu-tushare220 接口龙虎榜、资金流向、财务报表等服务器阿里云 ECS7×24 小时运行OpenClaw 支持多子 Agent 架构我配置了 4 个子 Agentresearcher研究员、coder程序员、writer写手和trader交易员。本文的主角就是trader。三、系统架构设计3.1 两阶段每日循环整个系统的核心是一个两阶段每日循环graph TD A[16:30 收盘分析] -- B[拉取全市场行情] B -- C[更新持仓市值] C -- D[评估持仓持有/卖出/加仓] D -- E[基础选股筛选2000只] E -- F[精选候选标的3-5只] F -- G[生成次日交易计划 trade_plan.json] G -- H[推送分析摘要到飞书] I[09:45 开盘执行] -- J[解冻 T1 冻结仓位] J -- K[读取交易计划] K -- L[获取今日开盘价] L -- M[自主判断执行/调整/放弃] M -- N[逐笔执行交易] N -- O[推送成交报告到飞书] H -.-|过夜| I O -.-|等待收盘| A3.2 目录结构~/.openclaw/workspace/trading/ ├── data/ │ ├── portfolio.json # 账户与持仓 │ ├── strategy.md # Agent 自主维护的策略文档 │ └── trade_plan.json # 次日交易计划 ├── scripts/ │ ├── tushare_helper.py # TuShare 数据助手 │ ├── check_trade_day.py # 交易日判断 │ └── trade_engine.py # 模拟交易引擎 └── logs/ ├── trade_log.csv # 交易日志 └── cron.log # 定时任务日志3.3 关键设计原则Agent 决策脚本执行Agent 负责分析和决策Python 脚本负责数据拉取和交易执行严格模拟真实规则T1、涨跌停限制、手续费一个不少防止 Agent 作弊所有数据必须来自 TuShare禁止编造行情禁止直接修改 portfolio.json策略自主进化Agent 自己维护strategy.md每周复盘更新四、核心代码实现4.1 TuShare 数据助手tushare_helper.py这是 Agent 的眼睛——封装了所有行情数据接口# 核心函数一览 def get_trade_date(offset0): # 获取最近交易日 def is_trade_day(date_strNone): # 判断是否交易日 def get_daily_data(trade_date): # 全市场日线行情 def get_daily_basic(trade_date): # 基本面指标PE/PB/换手率 def get_stock_history(code, days): # 个股历史K线 def get_open_price(codes): # 获取开盘价 def screen_stocks(trade_date): # 基础选股筛选选股筛选逻辑——这是 Agent 选股的第一道过滤网def screen_stocks(trade_dateNone): basic get_daily_basic(trade_date) daily get_daily_data(trade_date) merged pd.merge(daily, basic, on[ts_code, trade_date]) # 选股范围上证A股 深市A股 创业板 # 排除科创板(688xxx)、北交所、ST股 filtered merged[ (merged[ts_code].str.startswith((00, 60, 30))) (~merged[ts_code].str.startswith(688)) (~merged[ts_code].str.contains(ST)) (merged[pct_chg] 9.9) # 排除涨停 (merged[pct_chg] -9.9) # 排除跌停 (merged[total_mv] 50) # 市值 50亿 (merged[turnover_rate] 1) # 换手率 1% ] # 创业板涨跌停为20%需单独处理 is_gem filtered[ts_code].str.startswith(30) gem_limit filtered[is_gem (filtered[pct_chg].abs() 19.9)] main_board filtered[~is_gem] filtered pd.concat([main_board, gem_limit]) return filtered.sort_values(vol, ascendingFalse)选股范围的考量✅上证A股60xxxx大盘蓝筹为主✅深市A股00xxxx中小盘标的丰富✅创业板30xxxx成长性强20% 涨跌停带来更多机会❌科创板688xxx门槛高、波动大暂不纳入❌北交所8/4xxxxx流动性不足4.2 模拟交易引擎trade_engine.py这是 Agent 的手——执行实际的买卖操作def buy_stock(code, name, price, shares, reason): # 1. 涨停检查涨停的股票无法买入 pct_chg get_current_pct_chg(code) limit 19.9 if code.startswith(30) else 9.9 if pct_chg limit: return {success: False, msg: f{name} 已涨停无法买入} # 2. 股数取整到100的倍数 shares (shares // 100) * 100 # 3. 计算费用佣金万2.5最低5元 commission max(amount * 0.00025, 5) # 4. 资金检查、扣款、更新持仓 # 5. T1 冻结当天买入的股票今天不能卖 # 6. 写入交易日志 CSV def sell_stock(code, price, sharesNone, reason): # 1. 跌停检查跌停的股票无法卖出 # 2. T1 检查今天买的不能今天卖 # 3. 计算费用佣金 印花税千1 # 4. 收款、更新持仓、写日志涨跌停硬拦截是一个重要的设计——即使 Agent 的决策出了偏差引擎层面也会阻止不可能的操作。这保证了模拟的真实性。4.3 手续费模型def calc_fee(amount, direction): commission max(amount * 0.00025, 5) # 佣金万2.5最低5元 stamp_tax amount * 0.001 if direction sell else 0 # 卖出印花税千1 return round(commission stamp_tax, 2)与真实 A 股完全一致让模拟结果更有参考价值。五、Agent 的大脑——AGENTS.md 规则配置OpenClaw 通过AGENTS.md文件给 Agent 下达指令。这是 trader Agent 的核心规则精简版## trader 子 Agent 模拟炒股系统 ### 每日工作流程 **阶段一收盘分析16:30** 1. 读取持仓 → 2. 拉行情 → 3. 更新市值 → 4. 评估持仓 → 5. 筛选新标的 → 6. 生成交易计划 → 7. 推送摘要 **阶段二开盘执行09:45** 1. 解冻T1 → 2. 读计划 → 3. 获取开盘价 → 4. 自主判断执行 → 5. 推送成交报告 ### 交易规则硬性 - T1、最小100股、佣金万2.5印花税千1 - 涨停不买、跌停不卖引擎自动拦截 - 仅限上证A股、深市A股、创业板 ### 风控红线 - 单股仓位 ≤ 30%总仓位 ≤ 80% - 单股止损 ≥ 8%总回撤 ≥ 10% 暂停交易 ### 绝对禁止 - 不允许编造行情数据 - 不允许修改历史交易记录 - 不允许绕过 trade_engine.py 直接改 portfolio.json这套规则的设计哲学是给 Agent 足够的自主权去决策但用硬规则约束它不能做危险的事。六、自动化Crontab 定时触发三个定时任务驱动整个系统# 收盘分析每个工作日 16:30 30 16 * * 1-5 /bin/bash ~/trading/scripts/trigger_close_analysis.sh # 开盘执行每个工作日 09:45 45 9 * * 1-5 /bin/bash ~/trading/scripts/trigger_open_execute.sh # 周末复盘每周日 10:00 0 10 * * 0 /bin/bash ~/trading/scripts/trigger_weekly_review.sh每个触发脚本都会先判断是否为交易日调用 TuShare 交易日历非交易日自动跳过。七、实战首秀Agent 的第一次收盘分析搭建完成后我在飞书给 trader Agent 发了第一条指令trader 请执行收盘分析流程这是第一次运行。Agent 的表现让我惊喜7.1 选股结果Agent 从 3699 只股票中经过基础筛选得到约 2400 只再根据自主制定的策略精选出5 只重点关注股票代码名称收盘价Agent 看好理由002475.SZ立讯精密49.83消费电子龙头量价配合300059.SZ东方财富21.56券商互联网龙头600930.SH华电新能6.80新能源赛道低价放量002130.SZ沃尔核材27.51核电概念601899.SH紫金矿业34.90有色资源龙头仅关注未买入7.2 自主制定的策略Agent 写入strategy.md的核心策略核心原则趋势跟踪 量价配合基础筛选价格 5-50 元、成交额 1 亿、涨幅 0-8%技术面MA5 MA10 多头排列仓位控制单股 ≤ 30%总仓位 ≤ 80%风控止损 -8%止盈 15%7.3 生成的交易计划计划明日买入 4 只股票总投入约 4 万元预留约 1 万现金20%完全符合风控规则。这一切都是 Agent 自主完成的我没有干预任何决策。八、测试验证过程在让 Agent 正式上岗之前我做了完整的测试8.1 数据接口测试# TuShare 连接 ✅ $ python3 tushare_helper.py trade_date 20260317 # 基础选股 ✅ —— 筛出 2422 只股票 $ python3 tushare_helper.py screen 共筛选出 2422 只股票 # 个股历史 ✅ —— 平安银行30天K线 $ python3 tushare_helper.py stock 000001.SZ 308.2 交易引擎测试# 初始账户 ✅ $ python3 trade_engine.py summary 初始资金50,000.00 元 当前现金50,000.00 元 # 模拟买入 ✅ $ python3 trade_engine.py buy 000001.SZ 平安银行 12.50 500 测试买入 买入 平安银行 500股 12.5花费 6255含佣金 5剩余现金 43745 # 佣金计算验证12.5 × 500 6250佣金 max(6250×0.00025, 5) 5 ✅ # 总花费 6250 5 6255 ✅所有测试一次通过九、踩过的坑问题原因解决方案tree: command not found阿里云 ECS 最小化安装没有 treeyum install -y tree或用find替代创业板涨跌停与主板不同创业板是 20%主板是 10%选股和交易引擎中分别处理可能买入涨停股选股筛除了但交易时没拦截trade_engine 加入涨跌停硬拦截科创板/北交所混入选股池初始代码只过滤了主板代码明确范围为上证深市创业板十、加装官方 TuShare Skill从够用到专业级前面的tushare_helper.py覆盖了选股和交易的核心需求但 TuShare 其实还有更多宝藏接口。好消息是TuShare 官方发布了一个OpenClaw 专属 Skillskills.sh/waditu-tushare覆盖220 数据接口安装后 Agent 可以直接调用。安装一行搞定# 备份旧版如有 mv ~/.openclaw/skills/tushare ~/.openclaw/skills/tushare.bak.old # 安装官方 Skill npx skills add https://github.com/waditu-tushare/skills --skill tushare # → Installation scope: Global # → Installation method: Symlink (Recommended) # → Proceed: Yes # 重启 Gateway openclaw gateway restart安全评估Gen Safe ✅ · Socket 0 alerts ✅ · Snyk Med Risk效果立竿见影安装后我在飞书问了一句查询今日沪深港通资金流向Agent 立刻返回了一份完整报告沪股通/深股通成交额与北向资金净买入沪股通十大成交股贵州茅台、兆易创新、紫金矿业……深股通十大成交股宁德时代、中际旭创、天孚通信……港股通成交股腾讯、阿里、小米、中海油……关键发现Agent 自动把资金流向数据和交易计划关联——立讯精密在深股通中排名第5获北向资金关注支持明日买入计划最后一条特别惊喜Agent 自主建立了不同数据源之间的关联这说明它的分析已经超越了单一数据维度。双通道架构现在 trader Agent 拥有两个互补的数据通道通道用途接口数tushare_helper.py模拟炒股专用选股、交易执行~10 个TuShare 官方 Skill深度分析龙虎榜、资金流向、筹码、财报、技术因子、新闻……220十一、后续计划手动验证期第 1 周每天手动触发观察 Agent 决策质量全自动运行第 2 周起切换到 crontab 全自动策略进化观察 Agent 是否会根据盈亏自主调整策略增加 Researcher 协作让 researcher Agent 搜索行业新闻trader 综合判断月度/季度收益对比与沪深 300 指数做基准对比十二、写在最后整个搭建过程大约花了一个傍晚。最让我惊喜的不是系统本身而是trader Agent 第一次运行就展现出了合理的投资逻辑——它会看量价关系、会分散仓位、会预留现金、会设置止损线。当然AI 炒股到底能不能赚钱还需要时间来验证。但至少OpenClaw 让我们能够快速搭建这样一个实验平台用极低的成本去探索 AI Agent 在金融领域的可能性。这不是炒股建议这是一次技术实验。但如果你也对 AI Agent 感兴趣不妨动手试试——毕竟5 万虚拟资金输了也不心疼 。相关资源OpenClaw 官方文档GitHubTuShare 数据接口tushare.pro本文完整代码和配置见附属指南页面如果这篇文章对你有帮助欢迎点赞收藏关注后续我会持续更新 trader Agent 的实盘表现和策略进化过程。标签OpenClawAI Agent模拟炒股TuShare飞书Kimi量化投资Python

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2422398.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

SpringBoot-17-MyBatis动态SQL标签之常用标签

文章目录 1 代码1.1 实体User.java1.2 接口UserMapper.java1.3 映射UserMapper.xml1.3.1 标签if1.3.2 标签if和where1.3.3 标签choose和when和otherwise1.4 UserController.java2 常用动态SQL标签2.1 标签set2.1.1 UserMapper.java2.1.2 UserMapper.xml2.1.3 UserController.ja…

wordpress后台更新后 前端没变化的解决方法

使用siteground主机的wordpress网站,会出现更新了网站内容和修改了php模板文件、js文件、css文件、图片文件后,网站没有变化的情况。 不熟悉siteground主机的新手,遇到这个问题,就很抓狂,明明是哪都没操作错误&#x…

网络编程(Modbus进阶)

思维导图 Modbus RTU(先学一点理论) 概念 Modbus RTU 是工业自动化领域 最广泛应用的串行通信协议,由 Modicon 公司(现施耐德电气)于 1979 年推出。它以 高效率、强健性、易实现的特点成为工业控制系统的通信标准。 包…

UE5 学习系列(二)用户操作界面及介绍

这篇博客是 UE5 学习系列博客的第二篇,在第一篇的基础上展开这篇内容。博客参考的 B 站视频资料和第一篇的链接如下: 【Note】:如果你已经完成安装等操作,可以只执行第一篇博客中 2. 新建一个空白游戏项目 章节操作,重…

IDEA运行Tomcat出现乱码问题解决汇总

最近正值期末周,有很多同学在写期末Java web作业时,运行tomcat出现乱码问题,经过多次解决与研究,我做了如下整理: 原因: IDEA本身编码与tomcat的编码与Windows编码不同导致,Windows 系统控制台…

利用最小二乘法找圆心和半径

#include <iostream> #include <vector> #include <cmath> #include <Eigen/Dense> // 需安装Eigen库用于矩阵运算 // 定义点结构 struct Point { double x, y; Point(double x_, double y_) : x(x_), y(y_) {} }; // 最小二乘法求圆心和半径 …

使用docker在3台服务器上搭建基于redis 6.x的一主两从三台均是哨兵模式

一、环境及版本说明 如果服务器已经安装了docker,则忽略此步骤,如果没有安装,则可以按照一下方式安装: 1. 在线安装(有互联网环境): 请看我这篇文章 传送阵>> 点我查看 2. 离线安装(内网环境):请看我这篇文章 传送阵>> 点我查看 说明&#xff1a;假设每台服务器已…

XML Group端口详解

在XML数据映射过程中&#xff0c;经常需要对数据进行分组聚合操作。例如&#xff0c;当处理包含多个物料明细的XML文件时&#xff0c;可能需要将相同物料号的明细归为一组&#xff0c;或对相同物料号的数量进行求和计算。传统实现方式通常需要编写脚本代码&#xff0c;增加了开…

LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器的上位机配置操作说明

LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器专为工业环境精心打造&#xff0c;完美适配AGV和无人叉车。同时&#xff0c;集成以太网与语音合成技术&#xff0c;为各类高级系统&#xff08;如MES、调度系统、库位管理、立库等&#xff09;提供高效便捷的语音交互体验。 L…

(LeetCode 每日一题) 3442. 奇偶频次间的最大差值 I (哈希、字符串)

题目&#xff1a;3442. 奇偶频次间的最大差值 I 思路 &#xff1a;哈希&#xff0c;时间复杂度0(n)。 用哈希表来记录每个字符串中字符的分布情况&#xff0c;哈希表这里用数组即可实现。 C版本&#xff1a; class Solution { public:int maxDifference(string s) {int a[26]…

【大模型RAG】拍照搜题技术架构速览:三层管道、两级检索、兜底大模型

摘要 拍照搜题系统采用“三层管道&#xff08;多模态 OCR → 语义检索 → 答案渲染&#xff09;、两级检索&#xff08;倒排 BM25 向量 HNSW&#xff09;并以大语言模型兜底”的整体框架&#xff1a; 多模态 OCR 层 将题目图片经过超分、去噪、倾斜校正后&#xff0c;分别用…

【Axure高保真原型】引导弹窗

今天和大家中分享引导弹窗的原型模板&#xff0c;载入页面后&#xff0c;会显示引导弹窗&#xff0c;适用于引导用户使用页面&#xff0c;点击完成后&#xff0c;会显示下一个引导弹窗&#xff0c;直至最后一个引导弹窗完成后进入首页。具体效果可以点击下方视频观看或打开下方…

接口测试中缓存处理策略

在接口测试中&#xff0c;缓存处理策略是一个关键环节&#xff0c;直接影响测试结果的准确性和可靠性。合理的缓存处理策略能够确保测试环境的一致性&#xff0c;避免因缓存数据导致的测试偏差。以下是接口测试中常见的缓存处理策略及其详细说明&#xff1a; 一、缓存处理的核…

龙虎榜——20250610

上证指数放量收阴线&#xff0c;个股多数下跌&#xff0c;盘中受消息影响大幅波动。 深证指数放量收阴线形成顶分型&#xff0c;指数短线有调整的需求&#xff0c;大概需要一两天。 2025年6月10日龙虎榜行业方向分析 1. 金融科技 代表标的&#xff1a;御银股份、雄帝科技 驱动…

观成科技:隐蔽隧道工具Ligolo-ng加密流量分析

1.工具介绍 Ligolo-ng是一款由go编写的高效隧道工具&#xff0c;该工具基于TUN接口实现其功能&#xff0c;利用反向TCP/TLS连接建立一条隐蔽的通信信道&#xff0c;支持使用Let’s Encrypt自动生成证书。Ligolo-ng的通信隐蔽性体现在其支持多种连接方式&#xff0c;适应复杂网…

铭豹扩展坞 USB转网口 突然无法识别解决方法

当 USB 转网口扩展坞在一台笔记本上无法识别,但在其他电脑上正常工作时,问题通常出在笔记本自身或其与扩展坞的兼容性上。以下是系统化的定位思路和排查步骤,帮助你快速找到故障原因: 背景: 一个M-pard(铭豹)扩展坞的网卡突然无法识别了,扩展出来的三个USB接口正常。…

未来机器人的大脑:如何用神经网络模拟器实现更智能的决策?

编辑&#xff1a;陈萍萍的公主一点人工一点智能 未来机器人的大脑&#xff1a;如何用神经网络模拟器实现更智能的决策&#xff1f;RWM通过双自回归机制有效解决了复合误差、部分可观测性和随机动力学等关键挑战&#xff0c;在不依赖领域特定归纳偏见的条件下实现了卓越的预测准…

Linux应用开发之网络套接字编程(实例篇)

服务端与客户端单连接 服务端代码 #include <sys/socket.h> #include <sys/types.h> #include <netinet/in.h> #include <stdio.h> #include <stdlib.h> #include <string.h> #include <arpa/inet.h> #include <pthread.h> …

华为云AI开发平台ModelArts

华为云ModelArts&#xff1a;重塑AI开发流程的“智能引擎”与“创新加速器”&#xff01; 在人工智能浪潮席卷全球的2025年&#xff0c;企业拥抱AI的意愿空前高涨&#xff0c;但技术门槛高、流程复杂、资源投入巨大的现实&#xff0c;却让许多创新构想止步于实验室。数据科学家…

深度学习在微纳光子学中的应用

深度学习在微纳光子学中的主要应用方向 深度学习与微纳光子学的结合主要集中在以下几个方向&#xff1a; 逆向设计 通过神经网络快速预测微纳结构的光学响应&#xff0c;替代传统耗时的数值模拟方法。例如设计超表面、光子晶体等结构。 特征提取与优化 从复杂的光学数据中自…