# EasyXT
**Repository Path**: kittenchen/EasyXT
## Basic Information
- **Project Name**: EasyXT
- **Description**: No description available
- **Primary Language**: Unknown
- **License**: MIT
- **Default Branch**: main
- **Homepage**: None
- **GVP Project**: No
## Statistics
- **Stars**: 0
- **Forks**: 0
- **Created**: 2026-03-14
- **Last Updated**: 2026-03-14
## Categories & Tags
**Categories**: Uncategorized
**Tags**: None
## README
# EasyXT - 模块化QMT量化交易工具集
[](https://www.python.org/)
[](LICENSE)
[](https://www.gtja.com/)
[](https://www.ptqmt.com)
> **注意**:本项目使用的是miniQMT环境。QMT有两个版本:完整版QMT(包含GUI界面)和miniQMT(轻量级API版本)。两者在API使用上基本一致,但在环境配置和部署方式上有显著区别。详细区别请参阅 [📖 QMT版本说明](docs/assets/QMT_VERSIONS.md)。
> 量化为王,策略致胜,我是只聊干货的王者 quant!
---
## 🎯 项目定位
**EasyXT 不是单一框架,而是一套模块化的量化交易工具集**,包含:
### 核心特性
- 🎯 **简化API**: 封装复杂的QMT接口,提供易用的Python API
- 💰 **真实交易**: 支持通过EasyXT接口进行真实股票交易
- 📊 **数据获取**: 集成qstock、akshare等多种数据源
- 📈 **技术指标**: 内置常用技术指标计算
- 🚀 **策略开发**: 提供完整的量化策略开发框架
- 📚 **学习实例**: 丰富的教学案例,从入门到高级
### 模块概览
| 模块 | 类型 | 说明 | 独立性 |
|------|------|------|--------|
| **easy_xt** | 📦 核心库 | QMT API的轻量级封装,提供简洁的数据/交易接口 | ✅ 可独立使用 |
| **easyxt_backtest** | 🔧 扩展工具 | 通用回测框架,支持多策略、多数据源 | ✅ 可独立使用 |
| **101因子平台** | 📊 独立应用 | 基于Streamlit的因子分析Web应用 | ✅ 完全独立 |
| **strategies** | 📁 策略集合 | 完整的交易策略示例(雪球跟单、网格交易等) | ⚠️ 依赖easy_xt |
| **学习实例** | 📚 教学案例 | 从入门到实战的代码教程 | ⚠️ 依赖easy_xt |
**核心理念**:按需选用,低耦合,清晰边界
---
## 🚀 快速导航
### 🤔 我该从哪里开始?
#### 我是新手,想学习量化交易
→ 📖 **[学习路径](#-学习路径)** → 从 `学习实例/` 开始
#### 我只需要API封装,要在自己的项目中使用
→ 📦 **[easy_xt API文档](easy_xt/README.md)** → 只需安装 `easy_xt`
#### 我想做策略回测
→ 🔧 **[回测系统指南](easyxt_backtest/README.md)** → 使用 `easyxt_backtest`
#### 我要用现成的策略
→ 📁 **[策略列表](strategies/README.md)** → 查看 `strategies/` 目录
#### 我想做因子分析
→ 📊 **[101因子平台](101因子/101因子分析平台/README.md)** → 独立Web应用
### 🔧 遇到问题了?
→ 🆘 **[疑难问题解答 (FAQ)](docs/assets/TROUBLESHOOTING.md)** ← **点击这里!**
- DuckDB数据库找不到?数据下载失败?
- 安装报错?运行失败?性能问题?
- 这里收集了最常见的问题和解决方案!
---
## 📦 核心模块说明
### 📁 详细项目结构
```
miniqmt扩展/
├── easy_xt/ # 核心API模块
│ ├── __init__.py
│ ├── api.py # 主API接口
│ ├── data_api.py # 数据接口
│ ├── trade_api.py # 交易接口
│ ├── advanced_trade_api.py # 高级交易接口
│ └── utils.py # 工具函数
├── easyxt_backtest/ # 回测框架
│ ├── data_manager.py # 数据管理器
│ ├── engine.py # 回测引擎
│ ├── performance.py # 性能分析
│ └── strategies/ # 策略实现
├── 101因子/ # 因子分析平台
│ └── 101因子分析平台/ # Streamlit应用
├── strategies/ # 策略集合
│ ├── xueqiu_follow/ # 雪球跟单
│ ├── grid_trading/ # 网格交易
│ ├── jq2qmt/ # 聚宽转QMT
│ └── tdxtrader/ # 通达信预警交易
├── 学习实例/ # 学习案例
│ ├── 01_基础入门.py
│ ├── 02_交易基础.py
│ └── ...
├── gui_app/ # GUI应用
│ ├── main_window.py
│ └── widgets/
├── tools/ # 开发工具
│ ├── debug_qmt_api.py
│ └── demos/
├── config/ # 配置文件
├── data/ # 数据存储
├── logs/ # 日志目录
├── xtquant/ # QMT相关文件(需手动安装)
├── requirements.txt # 依赖列表
└── README.md # 本文件
```
### 1️⃣ easy_xt - 核心库(可独立使用)
**定位**:轻量级QMT API封装库
**特点**:
- ✅ 简洁的Python接口,隐藏QMT复杂性
- ✅ 统一的数据获取(行情、财务、指数成分股等)
- ✅ 标准化的交易接口(下单、查询、持仓管理)
- ✅ **无依赖其他模块**,可单独集成到任何项目
**安装**:
```bash
pip install -e ./easy_xt
```
**使用示例**:
```python
from easy_xt import get_api
# 获取API实例
api = get_api()
# 获取行情数据
data = api.get_price(
['000001.SZ'],
start='20240101',
period='1d'
)
```
**📖 详细文档**:[easy_xt/README.md](easy_xt/README.md)
---
### 2️⃣ easyxt_backtest - 回测框架(可独立使用)
**定位**:通用量化策略回测框架
**特点**:
- ✅ 支持多种策略类型(选股策略、因子策略)
- ✅ 多数据源支持(DuckDB、QMT、Tushare)
- ✅ 完整的交易模拟(佣金、滑点、持仓管理)
- ✅ 详细的性能分析(夏普比率、最大回撤等)
- ✅ **不依赖101因子平台**,可独立使用
**安装**:
```bash
pip install -e ./easyxt_backtest
```
**使用示例**:
```python
from easyxt_backtest import BacktestEngine, DataManager
from easyxt_backtest.strategies import SmallCapStrategy
# 创建数据管理器(无需参数,自动使用QMT/Tushare)
data_manager = DataManager()
# 如果有DuckDB数据库,可以指定路径(可选,提速10倍)
# data_manager = DataManager(duckdb_path='D:/StockData/stock_data.ddb')
# 创建回测引擎
engine = BacktestEngine(initial_cash=1000000, data_manager=data_manager)
# 运行回测
strategy = SmallCapStrategy(select_num=5)
result = engine.run_backtest(strategy, '20230101', '20231231')
result.print_summary()
```
**💡 提示**:
- ✅ **不需要DuckDB** - 无参数即可使用QMT/Tushare数据
- 🚀 **DuckDB是可选的** - 如果有,速度提升10倍(查看[快速开始指南](QUICK_START.md))
**📖 详细文档**:[easyxt_backtest/README.md](easyxt_backtest/README.md)
---
### 3️⃣ 101因子分析平台(完全独立应用)
**定位**:基于Streamlit的因子研究Web应用
**特点**:
- ✅ 191个Alpha因子(Alpha101全系列 + Alpha191扩展)
- ✅ 可视化工作流编辑器(拖拽式构建策略)
- ✅ 完整的因子分析工具(IC分析、分层回测)
- ✅ **完全独立的Web应用**,不依赖其他模块
**启动**:
```bash
cd 101因子/101因子分析平台
python 启动增强版.py
```
访问:http://127.0.0.1:8510
**📖 详细文档**:[101因子分析平台/README.md](101因子/101因子分析平台/README.md)
---
### 4️⃣ strategies - 策略集合(依赖easy_xt)
**定位**:完整的实战策略示例
**包含策略**:
- ❄️ **雪球跟单**:自动跟随雪球组合调仓
- 🔲 **网格交易**:固定网格、高频分时网格
- 📡 **通达信预警交易**:基于通达信预警自动交易
- 🔄 **聚宽策略转QMT**:JQ2QMT适配器
**依赖关系**:依赖 `easy_xt` 核心库
**📖 详细文档**:[strategies/README.md](strategies/README.md)
---
### 5️⃣ 学习实例 - 教学案例(依赖easy_xt)
**定位**:从入门到实战的代码教程
**学习路径**:
1. **01_基础入门.py** - 数据获取和API使用
2. **02_交易基础.py** - 基础交易操作
3. **04_策略回测.py** - 策略开发与回测
4. **07_akshare数据获取** - 多数据源集成
5. **10_qstock真实案例** - 完整实战案例
**依赖关系**:依赖 `easy_xt` 核心库
---
## 🏗️ 项目架构图
```
EasyXT 项目结构
│
├── 【核心层】可独立使用
│ ├── easy_xt/ # 核心API封装库
│ │ └── 无任何其他依赖
│ │
│ └── easyxt_backtest/ # 回测框架
│ └── 可独立使用(不依赖101因子平台)
│
├── 【应用层】独立应用
│ └── 101因子/101因子分析平台/ # 因子分析Web应用
│ └── 完全独立,不依赖其他模块
│
└── 【示例层】依赖核心库
├── strategies/ # 策略集合(依赖easy_xt)
├── 学习实例/ # 教学案例(依赖easy_xt)
└── gui_app/ # GUI界面(依赖easy_xt)
```
**模块依赖关系**:
- `easy_xt` ← 零依赖,可独立使用
- `easyxt_backtest` ← 可独立使用(不依赖101因子)
- `101因子平台` ← 完全独立
- `strategies` → 依赖 `easy_xt`
- `学习实例` → 依赖 `easy_xt`
---
## 📚 学习路径
### 🚀 快速开始(5分钟上手)
#### 基础数据获取
```python
from easy_xt import EasyXT
# 创建API实例
api = EasyXT()
# 初始化数据服务
api.init_data()
# 获取股票价格
data = api.get_price('000001.SZ', count=100)
print(data.head())
```
#### 简单交易示例
```python
# 初始化交易服务
api.init_trade(USERDATA_PATH)
api.add_account(ACCOUNT_ID)
# 买入股票
order_id = api.buy(
account_id=ACCOUNT_ID,
code='000001.SZ',
volume=100,
price_type='market'
)
```
### 初学者路线
```bash
# 第1步:学习基础API
学习实例/01_基础入门.py
学习实例/02_交易基础.py
# 第2步:了解策略开发
学习实例/04_策略回测.py
# 第3步:运行现成策略
strategies/grid_trading/固定网格.py
```
### 进阶路线
```bash
# 第1步:学习回测框架
easyxt_backtest/examples/small_cap_backtest.py
# 第2步:开发自定义策略
easyxt_backtest/strategies/ (参考策略基类)
# 第3步:使用因子平台
cd 101因子/101因子分析平台
python 启动增强版.py
```
### 实战路线
```bash
# 第1步:部署雪球跟单
strategies/xueqiu_follow/启动雪球跟单.bat
# 第2步:部署通达信预警交易
strategies/tdxtrader/ (查看README)
# 第3步:监控和优化
gui_app/main_window.py
```
---
## ⚙️ 安装指南
### 环境要求
- Python 3.9+
- Windows系统(QMT限制)
- 已安装QMT客户端(标准版或miniQMT)
### 快速安装
#### 1️⃣ 安装xtquant(必需且重要)
**⚠️ 重要:本项目需要特殊版本的 xtquant,不能使用 pip 安装的官方版本!**
##### 为什么必须使用特殊版本?
不同券商的QMT版本发布节奏不一致,xtquant接口和行为存在差异。为避免连接失败、字段缺失、接口不兼容等问题,**本项目仅支持以下特定版本**。
##### 下载地址
🔗 **https://github.com/quant-king299/EasyXT/releases/tag/v1.0.0**
下载附件:`xtquant.rar`
##### 安装步骤
**方法 1:直接解压到项目根目录(推荐)**
1. 下载 `xtquant.rar`
2. 解压到本项目根目录(`miniqmt扩展/`)
3. 确保目录结构为:`miniqmt扩展/xtquant/`
**方法 2:解压到自定义目录 + 设置环境变量**
1. 解压到自定义目录,如:`C:\xtquant_special`
2. 设置环境变量 `XTQUANT_PATH`:
**PowerShell**:
```powershell
setx XTQUANT_PATH "C:\xtquant_special"
```
**CMD**:
```cmd
setx XTQUANT_PATH "C:\xtquant_special"
```
3. **重启终端/IDE** 使环境变量生效
##### 验证安装
```bash
python -c "from xtquant import datacenter; print('✓ xtquant 安装正确')"
```
如果报错 `cannot import name 'datacenter' from 'xtquant'`,说明 xtquant **未安装或版本不完整**。
##### 一键下载并解压(PowerShell)
```powershell
$url = "https://github.com/quant-king299/EasyXT/releases/download/v1.0.0/xtquant.rar"
$dest = "$PWD\xtquant.rar"
Invoke-WebRequest -Uri $url -OutFile $dest -UseBasicParsing
if (Test-Path "$env:ProgramFiles\7-Zip\7z.exe") {
& "$env:ProgramFiles\7-Zip\7z.exe" x -y "$dest" -o"$PWD"
} elseif (Get-Command 7z.exe -ErrorAction SilentlyContinue) {
7z x -y "$dest" -o"$PWD"
} else {
Write-Host "未检测到 7-Zip,请手动解压 $dest 到项目根目录"
}
Remove-Item $dest -ErrorAction SilentlyContinue
if (Test-Path "$PWD\xtquant") { Write-Host "✓ xtquant 安装完成" } else { Write-Host "✗ xtquant 目录未找到,请检查解压" }
```
#### 2️⃣ 安装核心库
```bash
# 安装easy_xt核心库
pip install -e ./easy_xt
# 验证安装
python -c "from easy_xt import get_api; print('✓ 安装成功')"
```
#### 3️⃣ 按需安装扩展模块
```bash
# 如果需要回测功能
pip install -e ./easyxt_backtest
# 如果需要因子平台
cd 101因子/101因子分析平台
pip install -r requirements.txt
```
---
### ⚙️ 首次使用配置(重要)
#### 配置 Tushare Token(如果需要使用数据下载功能)
如果你需要使用 **Tushare 数据下载功能**,必须配置Token。
##### 步骤 1:获取 Tushare Token
1. 访问 [Tushare Pro](https://tushare.pro) 注册账号
2. 登录后进入「用户中心」→「接口Token」
3. 复制你的 Token(类似:`xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx`)
##### 步骤 2:配置环境变量文件
**方法 A:使用 .env 文件(推荐)**
1. 复制配置文件模板:
```bash
# Windows PowerShell
Copy-Item .env.example .env
# Windows CMD
copy .env.example .env
# Linux/Mac
cp .env.example .env
```
2. 编辑 `.env` 文件,填写你的 Token:
```env
TUSHARE_TOKEN=你的Token(替换这一行)
```
3. 保存文件
**方法 B:直接设置环境变量**
```powershell
# PowerShell
setx TUSHARE_TOKEN "你的Token"
# CMD
setx TUSHARE_TOKEN "你的Token"
```
**方法 C:在代码中设置(不推荐,仅用于测试)**
```python
import os
os.environ['TUSHARE_TOKEN'] = '你的Token'
```
##### 步骤 3:验证配置
```bash
python -c "import os; from dotenv import load_dotenv; load_dotenv(); print('✓ Token:', os.getenv('TUSHARE_TOKEN')[:10] + '...')"
```
##### 常见问题
**Q: 不配置 Token 会影响哪些功能?**
A: 以下功能会受影响:
- ❌ 无法使用 Tushare 数据源(回测时自动降级到其他数据源)
- ❌ 无法下载股票列表、财务数据等
- ✅ QMT本地数据仍可正常使用
- ✅ 其他不依赖Tushare的功能不受影响
**Q: Token 会被泄露吗?**
A: `.env` 文件已被加入 `.gitignore`,不会提交到Git。请勿手动提交包含Token的文件。
**Q: 如何获取 Token?需要付费吗?**
A: Tushare Pro采用积分制:
- 注册后会获得一些初始积分,可兑换基础权限的Token
- 基础功能(如股票行情、基础数据)所需积分较少
- 高级功能(如财务数据、高频数据)需要更多积分,可能需要充值
- 详细积分规则:https://tushare.pro/document/2
- 建议先试用基础功能,确认满足需求后再考虑充值
**Q: 不想用Tushare,有其他选择吗?**
A: 本项目支持多种数据源,可按需选择:
- **QMT本地数据**:如果有QMT终端,可直接使用本地历史数据
- **DuckDB本地数据库**:预先下载的数据文件(回测速度最快)
- **akshare**:免费数据接口(功能类似Tushare)
- **qstock**:免费数据接口
配置优先级:DuckDB > QMT > Tushare > akshare > qstock
---
### 📋 安装检查清单
在开始使用前,请确认以下事项:
- [ ] 已下载并解压特殊版本的 `xtquant`
- [ ] 验证 `from xtquant import datacenter` 不报错
- [ ] 已安装 `easy_xt` 核心库(`pip install -e ./easy_xt`)
- [ ] 如需回测,已安装 `easyxt_backtest`(`pip install -e ./easyxt_backtest`)
- [ ] 如需Tushare数据,已配置 Token
- [ ] QMT客户端已安装并登录
- [ ] Python 版本 ≥ 3.9
### 快速验证安装
运行以下命令验证所有组件:
```bash
# 1. 验证 xtquant
python -c "from xtquant import datacenter; print('✓ xtquant OK')"
# 2. 验证 easy_xt
python -c "from easy_xt import get_api; print('✓ easy_xt OK')"
# 3. 验证 easyxt_backtest(如果已安装)
python -c "import easyxt_backtest; print('✓ easyxt_backtest OK')"
# 4. 验证 Tushare Token(如果已配置)
python -c "from dotenv import load_dotenv; load_dotenv(); import os; print('✓ Tushare Token:', os.getenv('TUSHARE_TOKEN')[:10] + '...') if os.getenv('TUSHARE_TOKEN') else print('✗ Token未配置')"
```
---
## 🛠️ 开发者工具(可选)
项目包含一些开发者工具和演示脚本,位于 `tools/` 目录:
### 诊断工具
- `tools/debug_qmt_api.py` - 检查 easy_xt API 结构
- `tools/debug_data_api.py` - 验证数据连接
### 演示脚本
- 配置系统演示
- 监控告警演示
- 任务调度器演示
- 性能压测演示
- 日志管理演示
### 监控系统
```bash
# 启动监控服务
python start_monitor.py --config config/monitor_config.json
# 查看状态
python start_monitor.py --status
```
### 雪球跟单策略
**快速启动**:
```powershell
# 批处理脚本(Windows)
.\strategies\xueqiu_follow\启动雪球跟单.bat
# 或 Python 入口
python strategies\xueqiu_follow\start_xueqiu_follow_easyxt.py
```
**常见问题**:
- **Q**: 连接返回 -1 / "交易服务连接失败"?
- **A**: 99% 为 `qmt_path` 路径错误,请确保指向本机 `userdata` 或 `userdata_mini` 目录,避免 `0MT` 与 `userdata mini` 等拼写错误。
**详细配置**: 查看 `strategies/xueqiu_follow/README.md`
### JQ2QMT / QKA 服务(聚宽策略迁移)
如需将聚宽策略迁移到QMT:
```powershell
python strategies\jq2qmt\run_qka_server.py --account YOUR_ACCOUNT_ID --mini-qmt-path "C:\\Path\\To\\miniQMT"
```
详细文档:查看 `strategies/jq2qmt/README.md`
---
详细文档:查看 `tools/` 目录下的 README 文件
---
## 🎓 常见问题
> 💡 **遇到更复杂的问题?** 查看 **[🔧 疑难问题解答 (FAQ)](docs/assets/TROUBLESHOOTING.md)** 获取详细的故障排查指南!
### Q1: 我应该安装哪些模块?
**A**: 根据需求选择:
- **只要API** → 只安装 `easy_xt`
- **要做回测** → 安装 `easy_xt` + `easyxt_backtest`
- **因子研究** → 只使用 `101因子平台`(完全独立)
- **学习量化** → 安装 `easy_xt` + 看 `学习实例/`
- **使用现成策略** → 安装 `easy_xt` + 看 `strategies/`
### Q2: 这些模块之间有什么依赖关系?
**A**:
- `easy_xt`:无依赖,可独立
- `easyxt_backtest`:可独立,不依赖101因子平台
- `101因子平台`:完全独立
- `strategies`、`学习实例`:依赖 `easy_xt`
### Q3: 我可以在自己的项目中只使用easy_xt吗?
**A**: **完全可以!** `easy_xt` 就是设计成可独立使用的库:
```python
# 在你的项目中
from easy_xt import get_api
api = get_api()
data = api.get_price(['000001.SZ'], start='20240101', period='1d')
```
### Q4: 101因子平台必须配合easy_xt使用吗?
**A**: **不需要**。101因子平台是完全独立的Web应用,可以单独使用。
### Q5: 我是新手,应该从哪里开始?
**A**: 建议路径:
1. 阅读 `学习实例/01_基础入门.py`
2. 运行 `学习实例/02_交易基础.py`
3. 尝试 `学习实例/04_策略回测.py`
4. 需要时再学习其他模块
---
## 📊 与其他项目的对比
| 项目 | 定位 | 关系 |
|------|------|------|
| **miniQMT** | QMT官方Python接口 | EasyXT依赖的基础 |
| **EasyXT** | miniQMT的简化封装 | 本项目的核心库 |
| **QMT官方** | 迅投QMT交易平台 | 底层交易软件 |
| **聚宽JoinQuant** | 在线量化平台 | 通过JQ2QMT可集成 |
| **Backtrader** | 通用回测框架 | `easyxt_backtest`是QMT专用版 |
---
## 🤝 贡献指南
欢迎提交Issue和Pull Request!
### 开发流程
1. Fork 项目
2. 创建特性分支 (`git checkout -b feature/AmazingFeature`)
3. 提交更改 (`git commit -m 'Add some AmazingFeature'`)
4. 推送到分支 (`git push origin feature/AmazingFeature`)
5. 开启 Pull Request
### 代码规范
- 使用 Python PEP 8 编码规范
- 添加详细的文档字符串
- 编写单元测试
---
## 📈 更新日志
### v1.0.0 (2025-01-11)
- ✅ 初始版本发布
- ✅ 完整的EasyXT API封装
- ✅ 丰富的学习实例
- ✅ 修复交易服务初始化问题
---
## 🔗 相关链接
- **项目主页**: https://github.com/quant-king299/EasyXT
- **问题反馈**: https://github.com/quant-king299/EasyXT/issues
- **网站**: https://www.ptqmt.com
- **微信公众号**: 王者quant
---
## 📄 许可证
MIT License - 详见 [LICENSE](LICENSE) 文件
---
## ⚠️ 风险提示
1. **投资风险**:量化交易存在投资风险,请谨慎操作
2. **测试环境**:建议先在模拟环境中测试策略
3. **资金管理**:合理控制仓位,设置止损止盈
4. **合规要求**:遵守相关法律法规和交易所规则
---
## 🙏 致谢
- [迅投QMT](https://www.gtja.com/) - 提供量化交易平台
- [qstock](https://github.com/tkfy920/qstock) - 股票数据获取
- [akshare](https://github.com/akfamily/akshare) - 金融数据接口
---
**免责声明**: 本项目仅供学习和研究使用,不构成投资建议。使用本项目进行实际交易的风险由用户自行承担。
---
## 关注公众号 / 加群交流
- 关注公众号:
- 欢迎加入QQ交流群:492287081(或扫码加入)
- 欢迎加入知识星球,获取更多量化交易干货和一对一答疑服务
