---
name: 分发-B站
description: 用于将“B站/”目录内指定章节批量上传到 B 站创作中心并保存为草稿。支持按 README.md 读取账号、密码、作者笔名、小说名称与文集映射信息，自动执行登录、按新建/修改分流填写标题与正文、完成发布设置（原创声明/文集）并保存草稿，同时回写章节Id或待回填状态到分发记录。关键词：B站上传、专栏草稿、批量传章、原创声明、文集、保存为草稿。
argument-hint: 给我 chapterPath 或 chapterPaths（位于“B站/”目录），我会按 README.md 的账号与书籍信息逐章上传并保存为草稿，同时回写章节Id或待回填状态。
---

# 上传指定章节到 B 站并保存草稿

用于把你指定的 1 章或多章，上传到 B 站对应账号下，并全部保存为草稿。

## 何时使用

- 你已经把待上传章节放入 `B站/` 目录。
- 你已经在 `B站/README.md` 写好账号、密码、作者笔名、小说名称、文集映射等信息。
- 你希望按固定流程自动完成：登录 → 判断新建/修改模式 → 填写标题与正文 → 发布设置 → 保存为草稿 → 回写分发记录。

## 不适用情形

- 你只想做文本润色，不需要打开网站上传。
- 你没有提供 B 站账号或必要元数据。
- 目标不是“保存为草稿”，而是“直接发布”。

## 输入前置要求（强制）

### 1) 章节文件目录

- 待上传文件必须放在 `B站/` 下。
- 你会明确指定要上传哪些章节（可单章，可多章）。
- 章节标题**不以文件名直接照抄为准**，必须从章节文件内容中提取并规范化后填写到页面标题框。

### 1.1) 章节标题提取与组装规则（强制）

- 必须从章节文件中提取：章节号（阿拉伯数字）、章节标题、正文、作者有话说。
- B 站章节号与章节标题共用**一个标题输入框**。
- 最终填入值必须是完整字符串：`第{绝对章节号}章 {章节标题}`。
- `章号` 与 `标题` 之间必须保留 **1 个空格**，例如：`第1章 天降奇缘`。
- 若提取到的标题行只有标题文本（如 `天降奇缘`），则必须自动组装成 `第{绝对章节号}章 天降奇缘`。

### 2) 元数据来源

- 必须读取 `B站/README.md`，至少提取以下信息：
  - B 站用户名
  - B 站密码
  - 作者笔名（用于元信息记录）
  - 小说名称（小说书名候选；最终以“书名判定规则”确定文集匹配名）
  - 文集映射信息（书名与 B 站文集名称的对应关系）

### 3) 分发记录来源（强制）

- 必须读取 `B站/分发记录.md`：
  - 若文件不存在，先创建后再执行分发。
  - 用于查询“章节 -> 章节Id”映射，判定该章是“新建模式”还是“修改模式”。

### 4) 书名判定规则（强制）

- B 站目录中的“小说名称”即小说书名。
- 若小说无分部：小说书名使用该平台目录 `README.md` 中的“小说名称（小说书名）”。
- 若小说有分部（多部）：小说书名使用该章节所在分部的分部名。

### 5) 章节Id待定场景的记录规则（强制）

> 当前已知：新建草稿后“如何稳定获得章节Id（aid）”方法待定。流程必须支持“先上传、后回填 aid”。

- 若新建后无法获取 `aid`：
  - 允许先将该章写入分发记录，`章节Id` 字段填 `TBD`；
  - 同时记录 `草稿定位键`：`B站草稿::{标准标题}`；
  - 同时记录 `内容指纹`（规范化正文哈希，建议 SHA-1）；
  - `备注` 标记“待回填章节Id（aid）”。
- 后续任一轮执行若成功识别 `aid`：
  - 必须把 `章节Id` 从 `TBD` 更新为真实 `aid`，并更新 `更新时间` 与备注。

### 6) `分发记录.md` 模板（首次创建直接使用）

```markdown
# B站分发记录

> 用途：记录“章节唯一键 -> B站章节Id/待回填状态”映射，供分发流程判断“新建模式/修改模式”。

## 字段说明

- `章节唯一键`：固定格式 `B站文集名|分部名|绝对章号|章名`（无分部时分部名填 `NA`）
- `B站文集名`：对应 `B站/README.md` 中目标文集名（按书名判定规则映射）
- `章节Id`：编辑地址中的 `aid` 参数（未知时填 `TBD`）
- `草稿定位键`：固定格式 `B站草稿::{标准标题}`
- `内容指纹`：规范化正文的哈希值（建议 SHA-1）
- `最近操作`：`新建` 或 `修改`
- `更新时间`：`YYYY-MM-DD HH:mm:ss`
- `备注`：可选

## 记录表

|章节唯一键|B站文集名|章节Id|草稿定位键|内容指纹|最近操作|更新时间|备注|
|:--|:--|:--|:--|:--|:--|:--|:--|
```

### 7) `README.md` 模板（首次创建直接使用）

当 `B站/README.md` 不存在时，必须按以下模板创建：

```markdown
# B 站分发配置

> 用途：存储 B 站账号、书籍信息与文集映射。分发流程将读取此文件。

## 账号信息

- 用户名：`your_username`
- 密码：`your_password`

## 作者信息

- 作者笔名：`笔名`

## 书籍与文集映射

### 无分部小说

| 小说名称 | 目标文集名 |
|:--|:--|
| 作品名 | 文集名称 |

### 有分部小说

| 分部号 | 分部名 | 目标文集名 |
|:--|:--|:--|
| 第1部 | 分部一书名 | 文集名称一 |
| 第2部 | 分部二书名 | 文集名称二 |

## 字段说明

- `小说名称` / `分部名`：必须精确匹配 SKILL 中的"书名判定规则"
- `分部号`：必须使用 `第N部` 规范格式（如 `第1部`、`第2部`），并与 `分部名` 一一对应，不得错位或复用
- `目标文集名`：B 站创作中心已创建的长文合集名称
- `作者笔名`：用于原创声明与元信息记录

## 安全提醒

- 本文件包含明文密码，请妥善保管。
- 本文件应存入 `.gitignore`，不提交到公开仓库。
```

## 执行流程（强制按序）

### 步骤 1：读取本地输入

1. 读取并解析 `B站/README.md`。
2. 确认已获得：账号、密码、作者笔名、目标小说名、目标文集名（按书名判定规则映射）。
3. 读取 `B站/分发记录.md`，建立“章节唯一键 -> 章节Id/草稿定位键/内容指纹”映射。
4. 读取你指定的章节文件，提取每章：卷号、章号（阿拉伯数字）、章节标题、正文、作者有话说。

### 步骤 1.5：计算绝对章节编号（不分卷口径）

1. 章节编号统一使用“绝对章节编号”口径，不使用卷内局部编号。
2. 计算方式：
   - 读取 `分发记录.md` 中同一目标文集下全部已记录章节；
   - 依据 `绝对章号`排序后，计算当前章节的绝对序号。
3. B 站不分卷发布场景，章节号使用绝对章节号，计算公式为：
   - `绝对章节号 = 前面各卷章节数之和 + 该章节在所在卷的相对章号`。
4. 示例：
   - 若第1卷有90章、第2卷有100章：
   - 第1卷第5章 → 绝对章节号第5章；
   - 第2卷第5章 → 绝对章节号第95章；
   - 第3卷第5章 → 绝对章节号第195章。
5. 若 `分发记录.md` 不存在或无历史记录，则按上述公式从已知卷章结构计算；无法确定前卷章数时需先补齐台账后再发布。

### 步骤 2：登录 B 站作者后台

1. **必须新开一个浏览器标签页**，并在该新标签页访问：
   - `https://member.bilibili.com/platform/home`
2. 该新标签页仅用于本次 B 站上传流程，不复用你当前正在进行其他任务的标签页。
3. 若出现未登录状态：
   - 进入登录流程并选择“密码登录”；
   - 输入 `README.md` 中的用户名和密码完成登录。
4. 登录后保持在 B 站创作中心后台。

### 步骤 3：新建/修改分流

1. 每章开始前，先查 `B站/分发记录.md`：
   - 若已有有效 `章节Id`（非 `TBD`）：走**修改模式**。
   - 若无 `章节Id` 或 `章节Id=TBD`：走**新建模式**。

2. 新建模式：
   - 访问：
   - `https://member.bilibili.com/platform/upload/text/new-edit`

3. 修改模式：
   - 访问：
   - `https://member.bilibili.com/platform/upload/text/new-edit?aid={章节Id}`

### 步骤 4：填写标题与正文

1. 在标题输入框填写：`第{绝对章节号}章 {章节标题}`。
2. 在正文编辑区粘贴该章正文。
3. 必须确保正文来自你指定的章节文件，不得错章串章。

### 步骤 5：发布设置（强制）

#### 5.1 创作声明（必选）

- 在“发布设置”中必须勾选“声明此文章为原创”。

#### 5.2 文集（必选）

- 在“发布设置”中点击“选择文集”。
- 在弹窗中勾选与小说名称一致的目标文集。
- 点击“确定”。

### 步骤 6：保存草稿并回写记录

1. 点击“保存为草稿”。
2. 等待页面反馈保存成功（或等价成功提示）。
3. 写回 `B站/分发记录.md`：
   - 若已知 `aid`：写入真实 `章节Id`；
   - 若未知 `aid`：写入 `章节Id=TBD`，并写入 `草稿定位键` 与 `内容指纹`；
   - 同步更新 `最近操作`、`更新时间` 与 `备注`。

### 步骤 7：多章循环

- 创建或修改更多章节时，严格循环步骤 3～7。
- 每章都必须重新校验：当前章节是新建还是修改、发布设置是否已完整勾选、分发记录是否已回写。

## 关键边界与硬规则

- 必须只上传用户明确指定的章节，不得擅自扩展范围。
- 步骤 2 必须使用**新标签页**进入 B 站后台，禁止占用用户正在使用的原标签页。
- 作者后台入口固定为：`https://member.bilibili.com/platform/home`。
- 登录动作固定为“密码登录 + 输入账号密码”。
- 新建与修改 URL 必须按分发记录自动分流，禁止混用。
- 标题必须使用合并格式：`第X章 标题文本`（`X` 为绝对章节号，章号与标题之间有 1 个空格）。
- “发布设置”两项必须满足：原创声明已勾选 + 已选择匹配文集并确认。
- 每章最终保存动作必须是“保存为草稿”。
- 若新建后仍无法获取 `aid`，必须回写 `TBD` 与定位信息，不得遗漏记录。
- 账号密码仅用于当次登录，不写入产物文件、不外泄。

## 失败与回退处理

- 登录失败：提示账号/密码错误并停止，不继续后续章节。
- 出现二次验证（验证码/短信验证/风控）：必须立即暂停流程，等待用户手动完成验证并明确反馈“登录完成”；在收到该反馈前不得继续任何后续步骤。
- 页面元素缺失（如“创作声明”“选择文集”改版）：记录失败步骤并停止该章。
- 文集列表无匹配：停止保存，提示先创建或核对文集名称。
- “保存为草稿”失败：本章标记失败；重试后仍失败则保留失败记录并继续下一章（除非用户要求遇错即停）。
- 新建后无法获得 `aid`：按 `章节Id=TBD` 回写并标记“待回填章节Id”，后续继续可执行。
- `分发记录.md` 写入失败：流程标记为“部分失败（记录未落盘）”，并提示人工补录。

## 实操经验沉淀（B站）

- 登录后先确认编辑页可访问，再开始批量分发，能减少中途跳登录页导致的中断。
- 每章保存前先完成“原创声明 + 文集确认”，可避免保存后返工。
- 在 `aid` 方法未确定阶段，使用 `TBD + 草稿定位键 + 内容指纹` 可以稳定跟踪草稿状态。
- 每章结束以“保存为草稿成功”提示为唯一完成信号，没有成功提示就不算完成。

## 完成检查清单

- 已读取 `B站/README.md` 并提取必需字段。
- 已登录 B 站后台并完成密码登录。
- 已在每章开始前查询 `B站/分发记录.md` 并正确区分新建/修改模式。
- 每章均完成绝对章节号计算或校验（不分卷单序列口径）。
- 每章均完成：标题、正文、发布设置两项、点击“保存为草稿”。
- 每章保存后均已回写 `B站/分发记录.md`（含章节Id或 `TBD` 状态）。
- 已输出每章结果（成功/失败及原因）。
