# MoFin 架构改革 — 变更日志 > 日期:2026-06-29 ~ 2026-07-03 > 执行:Sisyphus (小小莫) + Zhiwei (知微) --- ## 2026-07-03 — JSON 彻底移除 + 币种架构修正 ### JSON→DB 全面迁移 (32+ 文件) **数据层** - `mo_data.py`:删除所有 JSON fallback,纯 SQLite 读取 - `mofin_db.py`: - `write_holding_strategy` 改为 DELETE+INSERT(旧 ON CONFLICT 静默失败) - `holding_strategies` 新增 10 列:avg_price, decision_timestamp, note, quality_check, quality_checked_at, quality_issues_json, position_advice, signal_factors_json, time_horizon, decision_type - 新增 `live_prices` / `mtf_cache` / `capital_flow_cache` 三张表 + 读写函数 - 已有 `market_snapshots` 表接替 market.json **server.py** - 新增 `_save_portfolio` / `_save_decision` / `_save_watchlist` 写函数 - 所有 13 个 API 写端点切到 DB,读端点删除 JSON fallback **脚本层** - 15 个文件 `json.load → mo_data.read_*()` - 12 个文件 `json.dump → mofin_db.write_*()` 或直接删除 - strategy_lifecycle JSON 冷备行全部删除 - branch_scanner / prune_branches 切到 DB - system_audit / stale_push_wlin / refresh_mtf_cache JSON→DB **LLM Prompt** - evaluation-daily v2:`evaluation.json` → DB 表 - knowledge-extraction v1:`decisions.json` → DB 表 - analytics.py:删除 JSON 路径常量 **已移除的 JSON 文件**(不再被任何代码读写) - portfolio.json / decisions.json / watchlist.json - live_prices.json / multi_tf_cache.json / market.json / capital_flow_cache.json ### 币种架构 **港股** — 个股 price/cost/stop_loss 存 **HKD**,`currency='HKD'` **A股** — 个股 price/cost/stop_loss 存 **CNY**,`currency='CNY'` **总资产** — `calc_total_assets()` 汇总时港股 HKD×汇率→CNY | 场景 | 港股 | A股 | |------|------|-----| | 个股显示(股软对照) | HKD | CNY | | 技术位(止损/止盈/买入区) | HKD | CNY | | 总资产 / 总市值 / P&L | CNY(汇总时转换) | CNY | ### 关键修复 - 根 `price_monitor.py` 与 `scripts/price_monitor.py` 不一致(前者存 HKD,后者转 CNY)→ 统一:存 HKD,不转换 - `s.get('price', 0)` 在 price 为 None 时返回 None 导致 TypeError → 改为 `s.get('price') or 0` - 东财 API 限流(之前 0.1s 间隔疯狂刷被封)→ 第一只失败立刻切腾讯兜底 ### 验证 ``` holdings: 19 (8 HKD + 11 CNY) decisions: 19 (8 HKD + 11 CNY) total_assets: stored = calculated ✅ ``` --- ## 2026-07-01 — 统一读取层 + 现金日志 ### 新增 - `mo_data.py` — `read_portfolio()` / `read_decisions()` / `read_watchlist()` - `mofin_db.py` — `cash_log` 表 + `write_cash_log` / `query_cash_log` ### 修改 - 16 个文件 `json.load → mo_data.read_*()` - HK 股成本 HKD→CNY 修复(import_holding_xls 导入时转换) --- ## 2026-06-30 — 初始架构重构 ### 新增 - `mo_models.py` — `calc_total_assets()`, `is_hk_stock()`, `get_hk_rate()`, `to_cny()`, `validate_portfolio()` - `mo_config.py` — 配置单例 - `mo_bridge.py` — DSA 集成桥 - `mo_provider.py` — DSA 数据源适配器 - `scripts/data_validate.py`, `holdings_reconciliation.py`, `process_trade.py`(知微) - DSA Web UI: `http://192.168.1.246:8001` ### 修改 - `price_monitor.py`:港股腾讯→东方财富 + 统一 total_assets - 8 个文件散落 `is_hk_stock` / `total_assets` 统一到 mo_models