You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

321 lines
13 KiB

<div align="center">
# 股票智能分析系統
[![GitHub stars](https://img.shields.io/github/stars/ZhuLinsen/daily_stock_analysis?style=social)](https://github.com/ZhuLinsen/daily_stock_analysis/stargazers)
[![CI](https://github.com/ZhuLinsen/daily_stock_analysis/actions/workflows/ci.yml/badge.svg)](https://github.com/ZhuLinsen/daily_stock_analysis/actions/workflows/ci.yml)
[![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT)
[![Python 3.10+](https://img.shields.io/badge/python-3.10+-blue.svg)](https://www.python.org/downloads/)
[![GitHub Actions](https://img.shields.io/badge/GitHub%20Actions-Ready-2088FF?logo=github-actions&logoColor=white)](https://github.com/features/actions)
[![Docker](https://img.shields.io/badge/Docker-Ready-2496ED?logo=docker&logoColor=white)](https://hub.docker.com/)
**基於 AI 大模型的 A股/港股/美股 智能分析系統**
自動分析自選股 → 生成決策儀表盤 → 多渠道推送Telegram/Discord/郵件/企業微信/飛書)
**零成本部署** · GitHub Actions 免費運行 · 無需伺服器
[**功能特性**](#-功能特性) · [**快速開始**](#-快速開始) · [**推送效果**](#-推送效果) · [**完整指南**](full-guide.md) · [**常見問題**](FAQ.md) · [**更新日誌**](CHANGELOG.md)
繁體中文[English] | (../README_EN.md) | [简体中文](../README.md)
</div>
## 💖 贊助商 (Sponsors)
<div align="center">
<a href="https://serpapi.com/baidu-search-api?utm_source=github_daily_stock_analysis" target="_blank">
<img src="../sources/serpapi_banner_zh.png" alt="輕鬆抓取搜尋引擎上的即時金融新聞數據 - SerpApi" height="160">
</a>
</div>
<br>
## ✨ 功能特性
| 模組 | 功能 | 說明 |
|------|------|------|
| AI | 決策儀表盤 | 一句話核心結論 + 精確買賣點位 + 操作檢查清單 |
| 分析 | 多維度分析 | 技術面 + 籌碼分布 + 輿情情報 + 實時行情 |
| 市場 | 全球市場 | 支援 A股、港股、美股 |
| 復盤 | 大盤復盤 | 每日市場概覽、板塊漲跌、北向資金 |
| 回測 | AI 回測驗證 | 自動評估歷史分析準確率,方向勝率、止盈止損命中率 |
| 推送 | 多渠道通知 | Telegram、Discord、郵件、企業微信、飛書等 |
| 自動化 | 定時運行 | GitHub Actions 定時執行,無需伺服器 |
### 技術棧與數據來源
| 類型 | 支援 |
|------|------|
| AI 模型 | Gemini免費、OpenAI 兼容、DeepSeek、通義千問、Claude、Ollama |
| 行情數據 | AkShare、Tushare、Pytdx、Baostock、YFinance |
| 新聞搜索 | Tavily、SerpAPI、Bocha、Brave |
### 內建交易紀律
| 規則 | 說明 |
|------|------|
| 嚴禁追高 | 乖離率 > 5% 自動提示風險 |
| 趨勢交易 | MA5 > MA10 > MA20 多頭排列 |
| 精確點位 | 買入價、止損價、目標價 |
| 檢查清單 | 每項條件以「符合 / 注意 / 不符合」標記 |
## 🚀 快速開始
### 方式一GitHub Actions推薦
**無需服務器,每天自動運行!**
#### 1. Fork 本倉庫
點擊右上角 `Fork` 按鈕(順便點個 Star 支持一下)
#### 2. 配置 Secrets
進入你 Fork 的倉庫 → `Settings``Secrets and variables``Actions``New repository secret`
**AI 模型配置(二選一)**
| Secret 名稱 | 說明 | 必填 |
|------------|------|:----:|
| `GEMINI_API_KEY` | [Google AI Studio](https://aistudio.google.com/) 獲取免費 Key | ✅* |
| `OPENAI_API_KEY` | OpenAI 兼容 API Key支持 DeepSeek、通義千問等 | 可選 |
| `OPENAI_BASE_URL` | OpenAI 兼容 API 地址(如 `https://api.deepseek.com/v1` | 可選 |
| `OPENAI_MODEL` | 模型名稱(如 `deepseek-chat` | 可選 |
> *注:`GEMINI_API_KEY` 和 `OPENAI_API_KEY` 至少配置一個
<details>
<summary><b>通知渠道配置</b>(點擊展開,至少配置一個)</summary>
| Secret 名稱 | 說明 | 必填 |
|------------|------|:----:|
| `TELEGRAM_BOT_TOKEN` | Telegram Bot Token@BotFather 獲取) | 可選 |
| `TELEGRAM_CHAT_ID` | Telegram Chat ID | 可選 |
| `TELEGRAM_MESSAGE_THREAD_ID` | Telegram Topic ID (用於發送到子話題) | 可選 |
| `DISCORD_WEBHOOK_URL` | Discord Webhook URL | 可選 |
| `DISCORD_BOT_TOKEN` | Discord Bot Token與 Webhook 二選一) | 可選 |
| `DISCORD_CHANNEL_ID` | Discord Channel ID使用 Bot 時需要) | 可選 |
| `EMAIL_SENDER` | 發件人郵箱(如 `xxx@qq.com` | 可選 |
| `EMAIL_PASSWORD` | 郵箱授權碼(非登錄密碼) | 可選 |
| `EMAIL_RECEIVERS` | 收件人郵箱(多個用逗號分隔,留空則發給自己) | 可選 |
| `WECHAT_WEBHOOK_URL` | 企業微信 Webhook URL | 可選 |
| `FEISHU_WEBHOOK_URL` | 飛書 Webhook URL | 可選 |
| `PUSHPLUS_TOKEN` | PushPlus Token[獲取地址](https://www.pushplus.plus),國內推送服務) | 可選 |
| `SERVERCHAN3_SENDKEY` | Server酱³ Sendkey[獲取地址](https://sc3.ft07.com/),手機軟體推播服務) | 可选 |
| `CUSTOM_WEBHOOK_URLS` | 自定義 Webhook支持釘釘等多個用逗號分隔 | 可選 |
| `CUSTOM_WEBHOOK_BEARER_TOKEN` | 自定義 Webhook 的 Bearer Token用於需要認證的 Webhook | 可選 |
| `SINGLE_STOCK_NOTIFY` | 單股推送模式:設為 `true` 則每分析完一隻股票立即推送 | 可選 |
| `REPORT_TYPE` | 報告類型:`simple`(精簡) 或 `full`(完整)Docker環境推薦設為 `full` | 可選 |
| `ANALYSIS_DELAY` | 個股分析和大盤分析之間的延遲避免API限流`10` | 可選 |
> 至少配置一個渠道,配置多個則同時推送。更多配置請參考 [完整指南](full-guide.md)
</details>
**其他配置**
| Secret 名稱 | 說明 | 必填 |
|------------|------|:----:|
| `STOCK_LIST` | 自選股代碼,如 `600519,hk00700,AAPL,TSLA` | ✅ |
| `TAVILY_API_KEYS` | [Tavily](https://tavily.com/) 搜索 API新聞搜索 | 推薦 |
| `BOCHA_API_KEYS` | [博查搜索](https://open.bocha.cn/) Web Search API中文搜索優化支持AI摘要多個key用逗號分隔 | 可選 |
| `BRAVE_API_KEYS` | [Brave Search](https://brave.com/search/api/) API隱私優先美股優化多個key用逗號分隔 | 可選 |
| `SERPAPI_API_KEYS` | [SerpAPI](https://serpapi.com/baidu-search-api?utm_source=github_daily_stock_analysis) 備用搜索 | 可選 |
| `TUSHARE_TOKEN` | [Tushare Pro](https://tushare.pro/weborder/#/login?reg=834638 ) Token | 可選 |
#### 3. 啟用 Actions
進入 `Actions` 標籤 → 點擊 `I understand my workflows, go ahead and enable them`
#### 4. 手動測試
`Actions``每日股票分析``Run workflow` → 選擇模式 → `Run workflow`
#### 5. 完成!
默認每個工作日 **18:00北京時間** 自動執行
### 方式二:本地運行 / Docker 部署
> 📖 本地運行、Docker 部署詳細步驟請參考 [完整配置指南](full-guide.md)
## 📱 推送效果
### 決策儀表盤
```
📊 2026-01-10 決策儀表盤
3隻股票 | 🟢買入:1 🟡觀望:2 🔴賣出:0
🟢 買入 | 貴州茅台(600519)
📌 縮量回踩MA5支撐乖離率1.2%處於最佳買點
💰 狙擊: 買入1800 | 止損1750 | 目標1900
✅多頭排列 ✅乖離安全 ✅量能配合
🟡 觀望 | 寧德時代(300750)
📌 乖離率7.8%超過5%警戒線,嚴禁追高
⚠️ 等待回調至MA5附近再考慮
---
生成時間: 18:00
```
### 大盤復盤
```
🎯 2026-01-10 大盤復盤
📊 主要指數
- 上證指數: 3250.12 (🟢+0.85%)
- 深證成指: 10521.36 (🟢+1.02%)
- 創業板指: 2156.78 (🟢+1.35%)
📈 市場概況
上漲: 3920 | 下跌: 1349 | 漲停: 155 | 跌停: 3
🔥 板塊表現
領漲: 互聯網服務、文化傳媒、小金屬
領跌: 保險、航空機場、光伏設備
```
## 配置說明
> 📖 完整環境變量、定時任務配置請參考 [完整配置指南](full-guide.md)
## 🧩 FastAPI Web 服務(可選)
本地運行時,可啟用 FastAPI 服務來管理配置和觸發分析。
### 啟動方式
| 命令 | 說明 |
|------|------|
| `python main.py --serve` | 啟動 API 服務 + 執行一次完整分析 |
| `python main.py --serve-only` | 僅啟動 API 服務,手動觸發分析 |
- 訪問地址:`http://127.0.0.1:8000`
- API 文檔:`http://127.0.0.1:8000/docs`
### 功能特性
- 📝 **配置管理** - 查看/修改自選股列表
- 🚀 **快速分析** - 通過 API 接口觸發分析
- 📊 **實時進度** - 分析任務狀態實時更新,支持多任務並行
- 📈 **回測驗證** - 評估歷史分析準確率,查詢方向勝率與模擬收益
### API 接口
| 接口 | 方法 | 說明 |
|------|------|------|
| `/api/v1/analysis/analyze` | POST | 觸發股票分析 |
| `/api/v1/analysis/tasks` | GET | 查詢任務列表 |
| `/api/v1/analysis/status/{task_id}` | GET | 查詢任務狀態 |
| `/api/v1/history` | GET | 查詢分析歷史記錄 |
| `/api/v1/backtest/run` | POST | 觸發回測 |
| `/api/v1/backtest/results` | GET | 查詢回測結果(分頁) |
| `/api/v1/backtest/performance` | GET | 獲取整體回測表現 |
| `/api/v1/backtest/performance/{code}` | GET | 獲取單股回測表現 |
| `/api/health` | GET | 健康檢查 |
## 項目結構
```
daily_stock_analysis/
├── main.py # 主程序入口
├── server.py # FastAPI 服務入口
├── src/ # 核心業務代碼
│ ├── analyzer.py # AI 分析器Gemini
│ ├── config.py # 配置管理
│ ├── notification.py # 消息推送
│ ├── storage.py # 數據存儲
│ └── ...
├── api/ # FastAPI API 模塊
├── bot/ # 機器人模塊
├── data_provider/ # 數據源適配器
├── docker/ # Docker 配置
│ ├── Dockerfile
│ └── docker-compose.yml
├── docs/ # 項目文檔
│ ├── full-guide.md # 完整配置指南
│ └── ...
└── .github/workflows/ # GitHub Actions
```
## 🗺️ Roadmap
> 📢 以下功能將視後續情況逐步完成,如果你有好的想法或建議,歡迎 [提交 Issue](https://github.com/ZhuLinsen/daily_stock_analysis/issues) 討論!
### 🔔 通知渠道擴展
- [x] 企業微信機器人
- [x] 飛書機器人
- [x] Telegram Bot
- [x] 郵件通知SMTP
- [x] 自定義 Webhook支持釘釘、Discord、Slack、Bark 等)
- [x] iOS/Android 推送Pushover
- [x] 釘釘機器人 (已支持命令交互 >> [相關配置](bot/dingding-bot-config.md)
### 🤖 AI 模型支持
- [x] Google Gemini主力免費額度
- [x] OpenAI 兼容 API支持 GPT-4/DeepSeek/通義千問/Claude/文心一言 等)
- [x] 本地模型Ollama
### 📊 數據源擴展
- [x] AkShare免費
- [x] Tushare Pro
- [x] Baostock
- [x] YFinance
### 🎯 功能增強
- [x] 決策儀表盤
- [x] 大盤復盤
- [x] 定時推送
- [x] GitHub Actions
- [x] 港股支持
- [x] Web 管理界面 (簡易版)
- [x] 美股支持
- [ ] 歷史分析回測
## ☕ 支持項目
<div align="center">
<a href="https://ko-fi.com/mumu157" target="_blank">
<img src="https://storage.ko-fi.com/cdn/kofi3.png?v=3" alt="Buy Me a Coffee at ko-fi.com" style="height: 40px !important;">
</a>
</div>
| 支付寶 (Alipay) | 微信支付 (WeChat) | Ko-fi |
| :---: | :---: | :---: |
| <img src="../sources/alipay.jpg" width="200" alt="Alipay"> | <img src="../sources/wechatpay.jpg" width="200" alt="WeChat Pay"> | <a href="https://ko-fi.com/mumu157" target="_blank"><img src="../sources/ko-fi.png" width="200" alt="Ko-fi"></a> |
## 貢獻
歡迎提交 Issue 和 Pull Request
詳見 [貢獻指南](CONTRIBUTING.md)
## License
[MIT License](../LICENSE) © 2026 ZhuLinsen
如果你在項目中使用或基於本项目进行二次开发,
非常歡迎在 README 或文檔中註明來源並附上本倉庫鏈接。
這將有助於項目的持續維護和社區發展。
## 聯繫與合作
- GitHub Issues[提交 Issue](https://github.com/ZhuLinsen/daily_stock_analysis/issues)
## Star History
**如果覺得有用,請給個 ⭐ Star 支持一下!**
<a href="https://star-history.com/#ZhuLinsen/daily_stock_analysis&Date">
<picture>
<source media="(prefers-color-scheme: dark)" srcset="https://api.star-history.com/svg?repos=ZhuLinsen/daily_stock_analysis&type=Date&theme=dark" />
<source media="(prefers-color-scheme: light)" srcset="https://api.star-history.com/svg?repos=ZhuLinsen/daily_stock_analysis&type=Date" />
<img alt="Star History Chart" src="https://api.star-history.com/svg?repos=ZhuLinsen/daily_stock_analysis&type=Date" />
</picture>
</a>
## 免責聲明
本項目僅供學習和研究使用,不構成任何投資建議。股市有風險,投資需謹慎。作者不對使用本項目產生的任何損失負責。
---