openclaw Skill 集成指南
本文档说明如何通过 openclaw Skill 调用 daily_stock_analysis 的 REST API,实现在 openclaw 对话中触发股票分析的能力。
本文档说明如何通过 openclaw Skill 调用 daily_stock_analysis 的 REST API,实现在 openclaw 对话中触发股票分析的能力。
概述
- 集成方式:openclaw Skill 通过 HTTP 调用 daily_stock_analysis(DSA)REST API
- 适用场景:已部署 DSA API 服务,希望在 openclaw 对话中触发分析(如「帮我分析茅台」「analyze AAPL」)
前置条件
- daily_stock_analysis 必须已运行:执行 python main.py --serve-only 或通过 Docker 部署,使 API 长期可用
- openclaw 需具备 HTTP 调用能力:如 system.run 执行 curl,或内置 HTTP 工具(如 api-tester 等)
- 说明:GitHub Actions 仅做定时任务,不长期暴露 API,需本地或 Docker 运行 DSA
核心 API 参考
| 接口 | 方法 | 用途 |
|---|---|---|
| /api/v1/analysis/analyze | POST | 触发分析(主入口) |
| /api/v1/analysis/status/{task_id} | GET | 异步任务状态 |
| /api/v1/agent/chat | POST | Agent 策略问股(需 AGENT_MODE=true) |
| /api/health | GET | 健康检查 |
触发分析请求体
{
"stock_code": "600519",
"report_type": "detailed",
"force_refresh": true,
"async_mode": false
}- stock_code:股票代码(必填)
- report_type:simple | detailed | brief
- force_refresh:布尔值,是否强制刷新(忽略缓存)
- async_mode:布尔值,false 时同步返回,true 时返回 202 + task_id 需轮询
注意:force_refresh、async_mode 为布尔类型,非字符串。
响应示例(同步模式)
{
"query_id": "abc123def456",
"stock_code": "600519",
"stock_name": "贵州茅台",
"report": {
"summary": {
"analysis_summary": "...",
"operation_advice": "持有",
"trend_prediction": "看多",
"sentiment_score": 75
},
"strategy": {
"ideal_buy": "1850",
"stop_loss": "1780",
"take_profit": "1950"
}
},
"created_at": "2026-03-13T10:00:00"
}重要限制与说明
- 仅支持股票代码:API 不接受中文名称(如「茅台」),需在 Skill 侧解析或提示用户提供代码(如 600519、AAPL)
- 同步模式耗时:async_mode: false 时,单次分析约 2–5 分钟,需确保 openclaw 或 HTTP 客户端超时足够
- 异步模式:async_mode: true 返回 202 + task_id,需轮询 GET /api/v1/analysis/status/{task_id} 直至 status: completed
股票代码格式
| 类型 | 格式 | 示例 |
|---|---|---|
| A股 | 6位数字 | 600519、000001、300750 |
| 北交所 | 8/4/92 开头 6 位,支持 BJ 前缀或 .BJ 后缀 | 920748、BJ920493、920493.BJ |
| 港股 | hk + 5位数字 | hk00700、hk09988 |
| 美股 | 1-5 字母(可选 .X 后缀) | AAPL、TSLA、BRK.B |
| 美股指数 | SPX/DJI/IXIC 等 | SPX、DJI、NASDAQ、VIX |
配置方式
在 ~/.openclaw/openclaw.json 中配置:
{
"skills": {
"entries": {
"daily-stock-analysis": {
"enabled": true,
"env": {
"DSA_BASE_URL": "http://localhost:8000"
}
}
}
}
}- 本地部署:http://localhost:8000 或 http://127.0.0.1:8000
- 远程部署:替换为实际 URL
- 建议:DSA_BASE_URL 勿以 / 结尾
错误响应格式
| 状态码 | error 字段 | 说明 |
|---|---|---|
| 400 | validation_error | 参数错误(如缺少 stock_code) |
| 409 | duplicate_task | 该股票正在分析中,拒绝重复提交 |
| 500 | internal_error / analysis_failed | 分析过程发生错误 |
完整 SKILL.md 示例
将以下内容保存到 ~/.openclaw/skills/daily-stock-analysis/SKILL.md:
---
name: daily-stock-analysis
description: 调用 daily_stock_analysis API 进行股票智能分析。当用户询问「分析茅台」「analyze AAPL」「帮我看看 600519」等时使用。仅支持股票代码,不支持中文名称。
metadata:
{"openclaw": {"requires": {"env": ["DSA_BASE_URL"]}, "primaryEnv": "DSA_BASE_URL"}}
---
## 触发条件
当用户请求分析某只股票时(如「分析茅台」「analyze AAPL」「帮我看看 600519」),使用本 Skill。
## 工作流程
1. **提取股票代码**:从用户消息中识别股票代码(如 600519、AAPL、hk00700)。若用户仅提供中文名称(如「茅台」),需提示用户提供股票代码,或使用常见映射(茅台→600519)。
2. **调用 API**:向 `{DSA_BASE_URL}/api/v1/analysis/analyze` 发送 POST 请求,请求体:{"stock_code": "<提取的代码>", "report_type": "detailed", "force_refresh": true, "async_mode": false, "skills": ["bull_trend"]}
> `skills` 为可选策略 ID 数组;历史字段 `strategies` 仍保留兼容,建议优先使用 `skills`。 3. **等待响应**:同步模式下分析约需 2–5 分钟,请确保 HTTP 客户端超时足够(建议 ≥300 秒)。 4. **解析结果**:从响应的 `report.summary` 中提取 `operation_advice`、`trend_prediction`、`analysis_summary`,从 `report.strategy` 中提取 `ideal_buy`、`stop_loss`、`take_profit`,以简洁格式呈现给用户。 5. **错误处理**: - 连接失败:提示检查 DSA 是否运行、DSA_BASE_URL 是否正确 - 400:检查 stock_code 格式 - 409:该股票正在分析中,可稍后重试或查询任务状态 - 500:提示查看 DSA 日志排查 ## 股票代码格式 - A股:6位数字(600519、000001) - 北交所:8/4/92 开头 6 位,支持 BJ 前缀或 .BJ 后缀(920748、BJ920493、920493.BJ) - 港股:hk + 5位数字(hk00700) - 美股:1–5 字母(AAPL、TSLA、BRK.B) - 美股指数:SPX、DJI、IXIC 等
Agent 策略问股(可选)
若 daily_stock_analysis 已启用 AGENT_MODE=true,可调用 Agent 策略问股接口,支持多轮对话与多种策略(缠论、均线金叉等):
# 将 {DSA_BASE_URL} 替换为实际配置的 API 地址(如 http://localhost:8000)
curl -X POST {DSA_BASE_URL}/api/v1/agent/chat \
-H 'Content-Type: application/json' \
-d '{"message": "用缠论分析 600519", "session_id": "optional-session-id"}'响应包含 content(分析结论)和 session_id(用于多轮对话)。
故障排查
| 现象 | 可能原因 | 处理建议 |
|---|---|---|
| 连接失败 | DSA 未运行、端口错误、防火墙 | 确认 python main.py --serve-only 已启动,检查 DSA_BASE_URL |
| 400 错误 | stock_code 格式错误或缺失 | 检查代码格式(见上文表格),确保请求体包含 stock_code |
| 500 错误 | AI 配置、数据源、网络问题 | 查看 DSA 日志,确认 GEMINI_API_KEY 等已配置 |
| Agent 400 | Agent 模式未启用 | 在 DSA 的 .env 中设置 AGENT_MODE=true |
| 分析超时 | 同步模式等待时间过长 | 增加 HTTP 客户端超时,或改用 async_mode: true 轮询状态 |
认证说明
默认情况下 DSA API 无需认证。若在 .env 中启用了 ADMIN_AUTH_ENABLED=true,则需在 Skill 调用时携带登录后获得的 Cookie,具体方式取决于 openclaw 的 HTTP 工具能力(当前 API 仅支持 Cookie 认证,不支持 Bearer Token)。