0c28031e81
- Add Web 端功能 section covering all features - Add web/ directory to project structure - Add Web startup instructions (backend + frontend) - Remove docs/superpowers/ (internal dev planning docs) Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
8.6 KiB
8.6 KiB
益选 OCR 订单处理系统
面向零售与分销场景的采购单处理工具,支持图片 OCR → Excel 规范化 → 模板填充 → 合并导出全流程,输出适配银豹 (PosPal) POS 系统。
核心功能
- 智能供应商识别:自动扫描 Excel 前 50 行内容特征,路由到对应的预处理逻辑(蓉城易购、烟草公司、杨碧月等)
- 图片 OCR:调用百度 OCR 表格识别 API,将采购单图片转为结构化 Excel
- 规则引擎:支持列映射、数据清洗、单位转换、规格推断、赠品标记等自动化规则
- 条码映射:可配置的条码转换规则,支持运行时编辑和云端同步
- 单价校验:自动比对
商品资料.xlsx,价差超过 1.0 元触发预警 - 云端同步:通过 Gitea REST API 在多台设备间同步配置文件(条码映射、供应商配置、商品资料、采购模板)
- 拖拽一键处理:拖入图片或 Excel 自动走完 OCR → 规范化 → 合并全流程
- CLI 接口:
headless_api.py支持无界面自动化调用
快速开始
桌面端 (GUI / CLI)
# 安装依赖
pip install -r requirements.txt
# GUI 模式
python 启动器.py
# CLI 模式
python headless_api.py data/input/xxx.xlsx
python headless_api.py data/input/xxx.jpg --barcode 6920584471055 --target 6920584471017
# 打包 EXE
python build_exe.py
Web 端
# 后端依赖
cd web/backend && pip install -r requirements.txt
# 前端依赖
cd web/frontend && npm install
# 启动后端 (端口 8000)
cd web && python -m uvicorn backend.main:app --host 0.0.0.0 --port 8000 --reload
# 启动前端开发服务器 (端口 5173)
cd web/frontend && npm run dev
# 构建前端到后端静态目录
cd web/frontend && npm run build
# 构建后直接访问 http://localhost:8000 即可
# 生产部署 (仅后端,前端已内嵌)
cd web && python -m uvicorn backend.main:app --host 0.0.0.0 --port 8000
默认账号: admin / admin123(首次登录后建议修改密码)
项目结构
├── 启动器.py # GUI 入口
├── headless_api.py # CLI 自动化接口
├── config.ini # 全局配置(API密钥、路径、Gitea)
├── config/
│ ├── config.ini # 配置副本
│ ├── barcode_mappings.json # 条码映射规则
│ └── suppliers_config.json # 供应商配置(列映射/规则引擎)
├── app/
│ ├── config/ # 配置管理(ConfigManager 单例)
│ ├── core/
│ │ ├── excel/ # Excel 处理(标准化、转换、合并、校验)
│ │ ├── handlers/ # 规则引擎、列映射、数据清洗、计算器
│ │ ├── ocr/ # 百度 OCR 客户端
│ │ ├── processors/ # 处理器(通用/烟草/OCR)
│ │ └── utils/ # 工具(日志、文件、字符串、云端同步、对话框)
│ ├── services/ # 业务服务(订单、OCR、处理器调度)
│ └── ui/ # GUI 模块(主题、日志、快捷键、主窗口)
├── web/ # Web 端
│ ├── backend/
│ │ ├── main.py # FastAPI 入口
│ │ ├── auth/ # JWT 认证(登录、Token、权限)
│ │ ├── routers/ # API 路由(文件、处理、记忆、条码、同步、任务、日志)
│ │ ├── services/ # 后端服务(任务管理、数据库、文件同步)
│ │ └── middleware/ # HTTP 日志中间件
│ └── frontend/
│ ├── src/
│ │ ├── views/ # 页面(Dashboard、Layout、文件管理、任务、日志等)
│ │ ├── stores/ # Pinia 状态管理(auth、processing)
│ │ ├── composables/ # 共享逻辑(useDebounce、useFileUtils、useFilePreview)
│ │ ├── api.ts # Axios 封装
│ │ └── router/ # Vue Router 路由
│ ├── package.json
│ └── vite.config.ts
├── templates/
│ ├── 银豹-采购单模板.xls # 输出模板(条码/采购量/赠送量/单价)
│ └── 商品资料.xlsx # 单价校验参考数据
├── data/
│ ├── input/ # 输入文件
│ ├── output/ # OCR 输出
│ ├── result/ # 最终采购单
│ └── web_data.db # Web 端数据库(SQLite)
└── tests/ # 单元测试(191 个)
Web 端功能
基于 Vue 3 + Element Plus + FastAPI 的浏览器端管理界面,与桌面端共享同一个 data/ 目录。
处理中心 (Dashboard)
- 一键全流程:上传图片或 Excel 后,一键完成 OCR → 标准化 → 合并全流程
- 批量 OCR / 批量处理:可单独执行 OCR 识别或 Excel 标准化步骤
- 实时进度:WebSocket 推送任务进度、日志、状态变更
- 多任务监控:同时查看多个运行中任务的进度和日志
- 任务重试:失败任务可查看错误详情并一键重试
文件管理
- 图片处理:管理
data/input/中的图片文件,支持上传、预览、批量 OCR、批量生成采购单 - 表格处理:管理
data/output/中的 Excel 文件,支持上传、预览、批量标准化处理 - 采购单管理:管理
data/result/中的采购单,支持预览、下载、合并、批量删除 - 实时同步:页面加载时自动同步磁盘文件到数据库,新文件立即可见
- 清除处理缓存:删除已处理的输出文件,允许重新处理
任务与日志
- 任务历史:查看所有处理任务的状态、进度、日志,支持按状态和类型筛选
- HTTP 日志:记录所有 API 请求,支持按方法和状态码筛选
记忆库
- 产品记忆:自动从 OCR 和处理结果中学习产品信息
- 置信度系统:根据出现次数自动评估记忆可靠度
- 搜索与管理:支持搜索、编辑、删除记忆条目
条码映射
- 映射规则管理:添加、编辑、删除条码转换规则
- 批量操作:支持批量导入和删除映射
云端同步
- Gitea 同步:通过 Gitea REST API 在多台设备间同步配置文件
- 一键推拉:选择文件推送或拉取,无需 git 客户端
系统配置
- 配置编辑:在浏览器中编辑系统配置(API 密钥、路径、参数)
- 修改密码:支持修改 Web 端登录密码
UI/UX
- 响应式布局:适配桌面和移动端,小屏幕自动切换为抽屉式导航
- 全局错误处理:未捕获的 Vue 错误自动显示用户提示
- 表单验证:修改密码等操作有完整的输入验证
供应商智能路由
| 供应商 | 识别特征 | 处理逻辑 |
|---|---|---|
| 烟草公司 | "专卖证号" 或 "510109104938" | B/E/G/H 列映射,数量×10,单价÷10 |
| 蓉城易购 | "RCDH" | E/N/Q/S 列映射,多条码分裂均分数量 |
| 杨碧月 | "经手人" + "杨碧月" | 列对齐,单位转换(件→瓶) |
| 通用供应商 | suppliers_config.json 配置 |
列映射 + 规则引擎 |
云端同步
通过 Gitea REST API 在多台设备间同步配置,无需 git 客户端。
支持同步的文件:
- 条码映射 (
barcode_mappings.json) - 供应商配置 (
suppliers_config.json) - 商品资料 (
templates/商品资料.xlsx) - 采购单模板 (
templates/银豹-采购单模板.xls)
配置方式:
- 系统设置 → 填入 Gitea 地址、仓库信息、Access Token
- 主窗口 → "云端同步" 按钮 → 选择文件推拉
Gitea 仓库: https://gitea.94kan.cn/houhuan/yixuan-sync-data
配置说明
| 配置项 | 文件 | 说明 |
|---|---|---|
| API 密钥 | .env 或 config.ini |
百度 OCR API,优先从环境变量读取 |
| Gitea Token | .env 或 config.ini |
云端同步 Token,优先从环境变量读取 |
| 供应商规则 | config/suppliers_config.json |
列映射、清洗规则、计算规则 |
| 条码映射 | config/barcode_mappings.json |
条码转换规则,运行时可更新 |
构建打包
pip install pyinstaller
python build_exe.py
# 输出: dist/OCR订单处理系统.exe
# 便携包: release/OCR订单处理系统.exe(含模板和商品资料)
测试
python -m pytest tests/ -v