Add "写长文" workflow with template selection support: - cdp_publish.py: new commands (long-article, select-template, click-next-step) - publish_pipeline.py: add --mode parameter (image-text / long-article) - SKILL.md: document long article flow (B.1-B.5 steps) - publish-workflow.md: add long article selectors, CLI usage, detailed steps
252 lines
7.9 KiB
Markdown
252 lines
7.9 KiB
Markdown
---
|
||
name: post-to-xhs
|
||
description: >
|
||
小红书内容发布技能。支持两种发布模式:(1) 上传图文模式 - 图片+短文;(2) 写长文模式 - 长篇文章+排版模板。
|
||
支持两种输入方式:用户提供完整内容和图片/图片URL,直接发布;或提供网页URL,自动提取内容和图片。
|
||
用户说"发长文"时使用长文模式,否则默认图文模式。
|
||
---
|
||
|
||
# 小红书内容发布
|
||
|
||
根据用户输入自动判断发布方式和发布模式,简化发布流程。
|
||
|
||
## 发布模式
|
||
|
||
- **上传图文**(默认):图片 + 短文,适合日常分享
|
||
- **写长文**:长篇文章 + 排版模板选择,适合深度内容。用户明确说"发长文"时使用
|
||
|
||
## 工作流程
|
||
|
||
```
|
||
用户输入
|
||
│
|
||
├─ 完整内容 + 图片/图片URL → 判断模式 → 发布流程
|
||
│
|
||
└─ 网页 URL → WebFetch 提取内容和图片
|
||
│
|
||
├─ 有图片 → 适当总结内容 → 判断模式 → 发布流程
|
||
│
|
||
└─ 无图片 → 提示用户手动下载图片
|
||
│
|
||
└─ 用户提供图片后 → 发布流程
|
||
```
|
||
|
||
## Step 1: 判断输入类型
|
||
|
||
根据用户输入判断:
|
||
|
||
- **完整内容模式**:用户提供了标题、正文内容、以及图片(本地路径或URL)
|
||
- **URL 提取模式**:用户只提供了一个网页 URL
|
||
|
||
如果不确定,询问用户。
|
||
|
||
## Step 2: 处理内容
|
||
|
||
### 完整内容模式
|
||
|
||
直接使用用户提供的标题和正文,跳到 Step 3。
|
||
|
||
### URL 提取模式
|
||
|
||
1. 使用 WebFetch 提取网页内容
|
||
2. 提取关键信息:标题、正文、图片URL
|
||
3. 适当总结内容,保持:
|
||
- 关键信息完整
|
||
- 语言自然流畅
|
||
- 适合小红书阅读习惯
|
||
|
||
#### 图片提取失败处理
|
||
|
||
如果从网页中提取不到图片URL,或图片URL无法访问,**必须**:
|
||
|
||
1. 告知用户图片提取失败
|
||
2. 提供原网页链接,请用户手动访问
|
||
3. 指导用户:
|
||
- 在浏览器中打开原网页
|
||
- 右键点击想要的图片 → "图片另存为" 或 "复制图片地址"
|
||
- 将保存的图片路径或复制的图片URL提供给我
|
||
4. 等待用户提供图片后再继续发布流程
|
||
|
||
**示例提示语**:
|
||
```
|
||
从网页中未能提取到可用的图片。请手动获取:
|
||
|
||
1. 打开原文链接:[URL]
|
||
2. 找到合适的配图,右键另存为本地,或复制图片地址
|
||
3. 将图片路径或URL发给我
|
||
|
||
拿到图片后我们继续发布。
|
||
```
|
||
|
||
## Step 3: 内容检查
|
||
|
||
### 标题检查
|
||
|
||
标题长度必须 ≤ 38,计算规则:
|
||
- 中文字符和中文标点(《》、,。等):每个计 2
|
||
- 英文字母/数字/空格/ASCII标点:每个计 1
|
||
|
||
如果超长,自动生成符合长度要求的新标题,保持语义一致。
|
||
|
||
### 正文格式
|
||
|
||
- 段落之间使用双换行分隔
|
||
- 语言自然,避免机器翻译感
|
||
- 简体中文
|
||
|
||
## Step 4: 发布到小红书
|
||
|
||
完整发布流程参考: [references/publish-workflow.md](references/publish-workflow.md)
|
||
|
||
### 4.1 用户确认内容
|
||
|
||
通过 `AskUserQuestion` 向用户展示即将发布的内容(标题、正文、图片),获得明确确认后再继续。
|
||
|
||
### 4.2 选择发布模式
|
||
|
||
通过 `AskUserQuestion` 让用户选择发布模式:
|
||
|
||
- **无头模式**(推荐):后台运行,速度快,无浏览器窗口。发布完成后直接报告结果。
|
||
- **有窗口模式**:显示浏览器窗口,可以预览内容。需要用户确认后再点击发布。
|
||
|
||
```
|
||
AskUserQuestion 示例:
|
||
问题:选择发布模式
|
||
选项:
|
||
- 无头模式(推荐):后台快速发布,无需预览
|
||
- 有窗口模式:显示浏览器,可预览确认
|
||
```
|
||
|
||
### 4.3 写入临时文件
|
||
|
||
将标题和正文写入临时 UTF-8 文本文件。不要在 `python -c` 中内联中文文本。
|
||
|
||
### 4.4 运行发布(根据模式分流)
|
||
|
||
#### A. 上传图文模式(默认)
|
||
|
||
根据用户选择的模式执行发布脚本:
|
||
|
||
**无头模式**(添加 `--headless` 参数):
|
||
```bash
|
||
python "C:\Users\admin\AI\.claude\skills\post-to-xhs\scripts\publish_pipeline.py" --headless --title-file title.txt --content-file content.txt --image-urls "URL1" "URL2"
|
||
```
|
||
|
||
**有窗口模式**(不添加 `--headless`):
|
||
```bash
|
||
python "C:\Users\admin\AI\.claude\skills\post-to-xhs\scripts\publish_pipeline.py" --title-file title.txt --content-file content.txt --image-urls "URL1" "URL2"
|
||
```
|
||
|
||
**其他参数**:
|
||
```bash
|
||
# 发布到指定账号
|
||
python ... --account myaccount ...
|
||
|
||
# 使用本地图片
|
||
python ... --images "C:\path\to\image.jpg"
|
||
```
|
||
|
||
处理输出:
|
||
- `NOT_LOGGED_IN` (exit code 1) → 脚本自动切换到有窗口模式,提示用户扫码登录,确认后重新运行
|
||
- `READY_TO_PUBLISH` (exit code 0) → 根据模式进入下一步
|
||
- Exit code 2 → 报告错误
|
||
|
||
#### B. 写长文模式
|
||
|
||
**Step B.1 — 填写长文内容 + 一键排版:**
|
||
|
||
```bash
|
||
python "C:\Users\admin\AI\.claude\skills\post-to-xhs\scripts\cdp_publish.py" long-article --title-file title.txt --content-file content.txt
|
||
```
|
||
|
||
可选 `--images img1.jpg img2.jpg` 插入图片到编辑器中。
|
||
|
||
输出中包含 `TEMPLATES: [...]` JSON 数组,为可用的排版模板名称列表。
|
||
|
||
**Step B.2 — 让用户选择模板:**
|
||
|
||
使用 `AskUserQuestion` 将模板名称作为选项展示给用户选择(从 TEMPLATES 输出中解析)。
|
||
|
||
**Step B.3 — 选择模板:**
|
||
|
||
```bash
|
||
python "C:\Users\admin\AI\.claude\skills\post-to-xhs\scripts\cdp_publish.py" select-template --name "用户选择的模板名"
|
||
```
|
||
|
||
**Step B.4 — 点击下一步并填写发布页正文描述:**
|
||
|
||
```bash
|
||
python "C:\Users\admin\AI\.claude\skills\post-to-xhs\scripts\cdp_publish.py" click-next-step --content-file content.txt
|
||
```
|
||
|
||
注意:发布页有独立的正文描述编辑器,必须通过 `--content` 或 `--content-file` 传入内容填写。
|
||
如果正文超过 1000 字,应压缩到 800 字左右再填入,保持语义不变。
|
||
|
||
**Step B.5 — 用户预览确认并发布:** 进入下方 4.5 步骤。
|
||
|
||
### 4.5 用户预览确认(仅有窗口模式 / 长文模式)
|
||
|
||
**仅当用户选择有窗口模式或使用长文模式时**,使用 `AskUserQuestion` 请用户在浏览器中检查预览,确认后再发布。
|
||
|
||
无头模式的图文发布跳过此步骤,直接进入 4.6。
|
||
|
||
### 4.6 点击发布
|
||
|
||
点击发布按钮:
|
||
|
||
```bash
|
||
python "C:\Users\admin\AI\.claude\skills\post-to-xhs\scripts\cdp_publish.py" click-publish
|
||
```
|
||
|
||
### 4.7 报告结果
|
||
|
||
根据命令输出告知用户发布是否成功。
|
||
|
||
## 重要提示
|
||
|
||
- **绝不自动发布** - 必须获得用户确认
|
||
- **图片要求** - 上传图文模式必须有图片;写长文模式图片可选
|
||
- **长文模式** - 必须让用户选择模板,不要自动选择
|
||
- **正文描述** - 长文模式的发布页有独立正文描述框,超过 1000 字需压缩到 800 字左右
|
||
- **无头模式**:使用 `--headless` 参数自动化发布。如需登录,脚本自动切换到有窗口模式
|
||
- 如果页面结构变化导致选择器失效,参考 `references/publish-workflow.md` 更新
|
||
|
||
## 账号管理
|
||
|
||
系统支持多个小红书账号,每个账号有独立的 Chrome profile。
|
||
|
||
### 列出账号
|
||
|
||
```bash
|
||
python "C:\Users\admin\AI\.claude\skills\post-to-xhs\scripts\cdp_publish.py" list-accounts
|
||
```
|
||
|
||
### 添加账号
|
||
|
||
```bash
|
||
python "C:\Users\admin\AI\.claude\skills\post-to-xhs\scripts\cdp_publish.py" add-account myaccount --alias "我的账号"
|
||
```
|
||
|
||
### 登录
|
||
|
||
```bash
|
||
# 默认账号
|
||
python "C:\Users\admin\AI\.claude\skills\post-to-xhs\scripts\cdp_publish.py" login
|
||
|
||
# 指定账号
|
||
python "C:\Users\admin\AI\.claude\skills\post-to-xhs\scripts\cdp_publish.py" --account myaccount login
|
||
```
|
||
|
||
### 切换账号
|
||
|
||
```bash
|
||
python "C:\Users\admin\AI\.claude\skills\post-to-xhs\scripts\cdp_publish.py" switch-account
|
||
python "C:\Users\admin\AI\.claude\skills\post-to-xhs\scripts\cdp_publish.py" --account otheraccount switch-account
|
||
```
|
||
|
||
### 设置默认账号
|
||
|
||
```bash
|
||
python "C:\Users\admin\AI\.claude\skills\post-to-xhs\scripts\cdp_publish.py" set-default-account myaccount
|
||
```
|