- 从服务器拉取完整代码 - 按框架规范整理项目结构 - 配置 Drone CI 测试环境部署 - 包含后端(FastAPI)、前端(Vue3)、管理端 技术栈: Vue3 + TypeScript + FastAPI + MySQL
162 lines
4.2 KiB
Markdown
162 lines
4.2 KiB
Markdown
# 统计分析功能 - 快速测试指南
|
||
|
||
## 🎉 功能已完成
|
||
|
||
统计分析页面的所有硬编码数据已全部替换为真实数据库对接!
|
||
|
||
## 📋 完成清单
|
||
|
||
✅ **后端开发**
|
||
- 创建统计服务层 (`app/services/statistics_service.py`)
|
||
- 创建6个RESTful API接口 (`app/api/v1/statistics.py`)
|
||
- 注册路由到主应用
|
||
|
||
✅ **前端开发**
|
||
- 创建API客户端 (`src/api/statistics.ts`)
|
||
- 完全重写统计分析页面 (`src/views/analysis/Statistics.vue`)
|
||
- 实现科目和时间范围筛选联动
|
||
- 添加完整的加载、错误、空状态处理
|
||
|
||
✅ **文档更新**
|
||
- 联调经验汇总已更新
|
||
- 实施总结文档已生成
|
||
|
||
## 🚀 快速测试
|
||
|
||
### 1. 启动后端 (Docker环境)
|
||
|
||
```bash
|
||
cd /Users/nongjun/Desktop/Ai公司/本地开发与测试
|
||
docker-compose -f docker-compose.dev.yml up -d
|
||
```
|
||
|
||
或者本地启动:
|
||
|
||
```bash
|
||
cd kaopeilian-backend
|
||
source venv/bin/activate
|
||
uvicorn app.main:app --reload --port 8000
|
||
```
|
||
|
||
### 2. 启动前端
|
||
|
||
```bash
|
||
cd kaopeilian-frontend
|
||
npm run dev
|
||
```
|
||
|
||
### 3. 访问统计分析页面
|
||
|
||
打开浏览器访问: http://localhost:5173/analysis/statistics
|
||
|
||
### 4. 测试API (可选)
|
||
|
||
```bash
|
||
cd kaopeilian-backend
|
||
source venv/bin/activate
|
||
python test_statistics_api.py
|
||
```
|
||
|
||
或使用curl:
|
||
|
||
```bash
|
||
# 获取关键指标
|
||
curl "http://localhost:8000/api/statistics/key-metrics?period=month"
|
||
|
||
# 获取成绩分布
|
||
curl "http://localhost:8000/api/statistics/score-distribution?period=month"
|
||
|
||
# 获取难度分析
|
||
curl "http://localhost:8000/api/statistics/difficulty-analysis?period=month"
|
||
```
|
||
|
||
## 🎯 测试要点
|
||
|
||
### 1. 基础功能
|
||
- [ ] 页面正常加载,显示加载动画
|
||
- [ ] 科目下拉显示真实课程列表
|
||
- [ ] 时间范围下拉有5个选项
|
||
- [ ] 关键指标卡片显示数值和环比
|
||
|
||
### 2. 图表展示
|
||
- [ ] 成绩分布饼图正确显示
|
||
- [ ] 难度分析雷达图正确显示
|
||
- [ ] 知识点掌握度柱状图正确显示
|
||
- [ ] 学习时长折线图正确显示
|
||
|
||
### 3. 筛选功能
|
||
- [ ] 选择不同科目,数据自动更新
|
||
- [ ] 选择不同时间范围,数据自动更新
|
||
- [ ] 所有图表和表格同步更新
|
||
|
||
### 4. 边界情况
|
||
- [ ] 新用户(无数据)显示空状态
|
||
- [ ] 网络错误时显示错误提示
|
||
- [ ] 可以点击"重新加载"按钮
|
||
|
||
### 5. 响应式
|
||
- [ ] 缩小浏览器窗口,布局自适应
|
||
- [ ] 图表自动调整大小
|
||
|
||
## 📊 功能说明
|
||
|
||
### 关键指标
|
||
1. **学习效率**: 正确题数 / 总题数
|
||
2. **知识覆盖率**: 已掌握知识点 / 总知识点
|
||
3. **平均用时**: 总考试时长 / 总题数
|
||
4. **进步速度**: 成绩环比增长率
|
||
|
||
### 图表展示
|
||
1. **成绩分布**: 优秀/良好/中等/及格/不及格的分布
|
||
2. **难度分析**: 不同难度题目的正确率
|
||
3. **知识点掌握度**: Top 6知识点的掌握情况
|
||
4. **学习时长**: 每日学习时长和练习时长
|
||
|
||
### 详细数据表格
|
||
- 按日期汇总的考试次数、平均分、学习时长、练习题数、正确率、进步指数
|
||
|
||
## 🔍 API文档
|
||
|
||
访问: http://localhost:8000/docs
|
||
|
||
查看所有统计分析API的完整文档和在线测试。
|
||
|
||
## ❓ 常见问题
|
||
|
||
### Q1: 页面显示"暂无数据"?
|
||
**A**: 确保数据库中有考试记录。可以先进行一次考试,然后再查看统计。
|
||
|
||
### Q2: API返回500错误?
|
||
**A**: 检查数据库连接,确保MySQL服务正常运行。
|
||
|
||
### Q3: 图表不显示?
|
||
**A**: 打开浏览器控制台(F12),查看是否有JavaScript错误。
|
||
|
||
### Q4: 科目下拉为空?
|
||
**A**: 确保数据库中有已发布的课程(status='published')。
|
||
|
||
## 📁 重要文件位置
|
||
|
||
### 后端
|
||
- 服务层: `/kaopeilian-backend/app/services/statistics_service.py`
|
||
- API路由: `/kaopeilian-backend/app/api/v1/statistics.py`
|
||
- 测试脚本: `/kaopeilian-backend/test_statistics_api.py`
|
||
|
||
### 前端
|
||
- API客户端: `/kaopeilian-frontend/src/api/statistics.ts`
|
||
- 页面组件: `/kaopeilian-frontend/src/views/analysis/Statistics.vue`
|
||
|
||
### 文档
|
||
- 联调经验: `/考培练系统规划/全链路联调/联调经验汇总.md`
|
||
- 实施总结: `/.cursor/plans/统计分析功能实施总结.md`
|
||
|
||
## 📞 需要帮助?
|
||
|
||
如有问题,请查看:
|
||
1. 浏览器控制台(F12) - 查看前端错误
|
||
2. 后端日志 - 查看API错误
|
||
3. 数据库日志 - 查看查询错误
|
||
|
||
## 🎊 祝您测试顺利!
|
||
|