程序员量化交易实战 16:先把模拟盘账本写清楚

第 15 篇完成了策略晋升门禁。通过门禁不等于可以真实交易,它只表示这个候选策略有资格进入更慢、更保守的纸面模拟盘观察。

第 16 篇先不做复杂撮合,也不接券商接口,只做一件事:把模拟盘账户账本写清楚。

为什么从账本开始

模拟盘的第一层可信度来自账本。

如果买入后现金没有扣对,卖出后持仓没有减对,手续费没有算进成本,后面的权益曲线、风控、调仓提醒都会建立在错误状态上。

这里先把几个常见名词说清楚:

名词在模拟盘里的含义
账本记录现金、持仓、成交和盈亏的账户状态
成交一笔订单被接受后形成的账户变更
平均成本当前持仓每股摊薄后的成本,买入手续费也会影响它
已实现盈亏卖出后真正落到账户里的盈亏
未实现盈亏当前持仓按最新价估算出来的浮动盈亏

账户状态

第 16 章新增 app/paper_ledger.py,核心对象很少:

@dataclass(frozen=True)
class PaperAccountState:
    cash: float
    positions: dict[str, PaperPositionState] = field(default_factory=dict)

持仓只保留当前需要的字段:代码、股数、平均成本和已实现盈亏。这里没有数据库,也没有异步任务,是一个纯函数账本,便于测试和复用。

执行买卖

下单入口是 apply_paper_order()

它会复用第 4 篇的 A 股交易规则:买卖股数按 100 股一手处理,买入检查现金,卖出检查可用持仓,并使用同一套手续费估算函数。

execution = apply_paper_order(
    account,
    trade_date=date(2026, 1, 8),
    symbol="000001.SZ",
    side="buy",
    price=10.0,
    shares=1234,
)

这个订单会被规范成 1200 股。账本返回 PaperExecution,其中既包含本次成交,也包含成交后的新账户状态。

市值和权益

账本还提供两个小函数:

account_market_value(account, last_prices)
account_total_equity(account, last_prices)

它们暂时只用最新价估算持仓市值。后续第 17 篇会把这些值组织成更完整的账户快照。

当前主线联动运行

当前主线仓库提供了一条从第 16 篇跑到第 20 篇的模拟盘示例:

git clone https://github.com/ax2/zi-quant-platform.git
cd zi-quant-platform
uv sync --extra dev
uv run python -m scripts.chapter_examples paper-flow

第 16 篇对应的是账本成交部分:

这次示例从 100000 现金开始,买入 000001.SZ 6400 股,成交金额 79744.00,费用 24.72,成交后现金剩 20231.28。这个截图比单独贴测试结果更有用,因为它展示了买入订单如何真实改变账户状态。

本章更新与代码仓库

本章更新内容:

  • 新增 app/paper_ledger.py
  • 实现模拟盘账户、持仓、成交执行结果和买卖更新逻辑。
  • 复用 A 股交易规则和手续费估算。
  • 新增 tests/test_paper_ledger.py,覆盖买入、现金不足、卖出、无持仓卖出和权益计算。
  • 在当前主线补充 scripts.chapter_examples paper-flow 联动示例,可真实运行第 16-20 篇模拟盘链路。
  • 补充账本、成交、平均成本、已实现盈亏和未实现盈亏等常见名词。

代码仓库:

https://github.com/ax2/zi-quant-platform

本章代码:

git clone https://github.com/ax2/zi-quant-platform.git
cd zi-quant-platform
git checkout chapter-16
uv sync --extra dev
uv run pytest tests/test_paper_ledger.py

第 16 章提交为 936cb5c,tag 为 chapter-16

本篇小结

模拟盘不是先做界面,也不是先做提醒。

第 16 篇把账户现金、持仓、成交和权益计算写成了可测试的账本函数。下一篇会在账本之上生成账户快照,让模拟盘状态可以被展示、风控和复盘。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值