docs/desktop-package.md
本项目可打包为桌面应用,使用 Electron 作为桌面壳,apps/dsa-web 的 React UI 作为界面。
/api/health 就绪后加载 UI.env 和数据库放在 exe 同级目录(便携模式)一键启动(开发模式):
powershell -ExecutionPolicy Bypass -File scripts\run-desktop.ps1
或手动执行:
static/)cd apps/dsa-web
npm install
npm run build
cd apps/dsa-desktop
npm install
npm run dev
首次运行时会自动从 .env.example 复制生成 .env。
powershell -ExecutionPolicy Bypass -File scripts\build-all.ps1
该脚本会依次执行:
当前 Windows 安装包使用 NSIS 向导式安装流程,仅支持当前用户安装且已禁用管理员提权,安装时可手动选择目标目录(例如非 C 盘)。安装器通过 NSIS .onVerifyInstDir 回调在安装器层面阻止选择 Program Files、Windows 等系统保护目录——选择这些路径时"下一步"按钮会被自动禁用。安装完成后,桌面端仍会按现有逻辑在安装目录旁生成/读取 .env、data/stock_analysis.db 和 logs/desktop.log。推荐使用默认的 per-user 安装目录。如果不想安装,仍可继续分发 win-unpacked 免安装包。
仓库已支持通过 GitHub Actions 自动构建桌面端并上传到 GitHub Releases:
.github/workflows/desktop-release.ymlv3.2.12)后自动触发release_tagdaily-stock-analysis-windows-installer-<tag>.exe,本地 apps/dsa-desktop/dist/ 中仍是 *Setup*.exedaily-stock-analysis-windows-noinstall-<tag>.zipdaily-stock-analysis-macos-x64-<tag>.dmgdaily-stock-analysis-macos-arm64-<tag>.dmg建议发布流程:
maindesktop-release 工作流自动构建并把两个平台安装包附加到对应 GitHub Releasecd apps/dsa-web
npm install
npm run build
pip install pyinstaller
pip install -r requirements.txt
python -m PyInstaller --name stock_analysis --onefile --noconsole --add-data "static;static" --hidden-import=multipart --hidden-import=multipart.multipart main.py
将生成的 exe 复制到 dist/backend/:
mkdir dist\backend
copy dist\stock_analysis.exe dist\backend\stock_analysis.exe
cd apps/dsa-desktop
npm install
npm run build
打包产物位于 apps/dsa-desktop/dist/。Windows 安装器会生成 *Setup*.exe,安装向导中可选择安装目录。
Windows 安装包模式下,安装器仅支持当前用户安装且已禁用管理员提权,用户可在安装向导中选择安装目录;安装器会在安装器层面阻止选择 Program Files、Windows 等系统保护目录(选择时"下一步"按钮自动禁用),安装完成后,应用会在安装目录旁生成/读取 .env、data/stock_analysis.db 和 logs/desktop.log。请保留默认的 per-user 安装位置或选择其他用户可写目录。
win-unpacked 免安装模式下,目录结构如下:
win-unpacked/
Daily Stock Analysis.exe <- 双击启动
.env <- 用户配置文件(首次启动自动生成)
data/
stock_analysis.db <- 数据库
logs/
desktop.log <- 运行日志
resources/
.env.example <- 配置模板
backend/
stock_analysis.exe <- 后端服务
.env 放在 exe 同目录下.env.example 复制生成exe 实际位于 .app 包内部,因此 .env、data/、logs/ 也会跟着落在应用包内容器里;替换新的 DMG / .app 时,旧配置会随旧应用包一起被覆盖.env 配置以下内容:
GEMINI_API_KEY 或 OPENAI_API_KEY:AI 分析必需STOCK_LIST:自选股列表(逗号分隔).env.example.env系统设置 -> 配置备份 可以直接看到 导出 .env 和 导入 .env 按钮导出 .env 会导出当前已保存的 .env 备份文件;页面上尚未点击“保存配置”的本地草稿不会被导出导入 .env 会读取备份文件中的键值并合并到当前桌面端配置中,导入后会立即触发配置重载建议:macOS 用户在升级 DMG 前先执行一次
导出 .env,这样即使旧.app被整体替换,也能在新版本里直接恢复配置
系统设置 -> 版本信息 中的“桌面端版本”由 Electron 主进程的 app.getVersion() 提供,并通过 preload bridge 暴露给前端npm run dev 与打包态 npm run build / 安装包都会复用同一条版本注入链路,不再在 preload.js 里维护独立硬编码版本号README.md 继续保留安装和运行入口说明;这类桌面端运行时细节统一落在本专题文档维护,避免入门文档膨胀/releases/latest),并与当前 app.getVersion() 做语义化版本比较系统设置 -> 版本信息 中新增“桌面端更新”区域,可手动点击“检查更新”查看状态并再次跳转下载页logs/desktop.log,设置页手动检查时才会展示错误状态logs/desktop.log 查看错误信息.env 文件存在且配置正确PyInstaller 打包时缺少模块,需要在 scripts/build-backend.ps1 中增加 --hidden-import。
确认 static/index.html 存在,如不存在需重新构建 React UI。
这是当前桌面端便携模式的已知行为:.env 放在打包后的应用目录旁,而 macOS 中这个目录通常位于 .app 包内部。升级或替换新的 DMG / .app 后,旧 .env 不会自动迁移,所以看起来像“配置丢了”。
处理方式:
导出 .env导入 .envWindows 分发现在有两种方式:
apps/dsa-desktop/dist/ 下的 *Setup*.exe,用户安装时可自行选择目标目录apps/dsa-desktop/dist/win-unpacked/ 整个文件夹打包发给用户使用 win-unpacked 免安装包时,用户只需:
.env 配置 API Key 和股票列表Daily Stock Analysis.exe 启动