Install
openclaw skills install book-pdf深度调研一个主题,生成100页+书籍级PDF手册。模块化HTML片段架构 + 语义化版本管理 + 多Agent并行写作 + Playwright渲染PDF。 当用户需要制作完整的PDF手册、电子书、橙皮书、参考指南时触发。即使用户只是说「做一本书」「做个PDF手册」「做个完整指南」「做一本XX的手册」也应触发。...
openclaw skills install book-pdf从一个主题到100页+专业PDF。五个阶段:调研 → 规划 → 写作 → 构建 → 版本更新。
npm install playwright && npx playwright install chromium| 需要时读取 | 文件 | 内容 |
|---|---|---|
| 写HTML片段时 | references/design-system.md | CSS变量、主题、组件HTML速查、视觉红线 |
| 新建项目时 | templates/ 目录 | 可直接复制的骨架文件(build.js/build-pdf.js/update.sh/styles.css) |
| 参考已有项目时 | 01-公众号写作/_过程文件/openclaw-guide/ | 首个实战项目(8 Part、35节、100页+) |
用 init 脚本一键创建项目骨架:
bash scripts/init-project.sh <项目目录> <手册标题>
# 示例:bash scripts/init-project.sh ./my-guide "Python完全指南"
自动创建目录结构、复制模板文件、生成 version.json/CHANGELOG.md/PROJECT.md、检查依赖。
{项目名}/
├── PROJECT.md # 项目中枢(大纲+进度+数据速查)
├── styles.css # 共享CSS(从templates/复制)
├── build.js # HTML合并脚本(从templates/复制,改FRAGMENT_ORDER)
├── build-pdf.js # Playwright PDF渲染(从templates/复制)
├── update.sh # 一键版本更新(从templates/复制)
├── version.json # {"version":"1.0.0","build":1,"lastUpdate":"","title":""}
├── CHANGELOG.md # 更新日志
├── fragments/ # 内容片段(纯HTML,不含<html><head>)
│ ├── 00-cover.html / 01-toc.html
│ ├── part{N}-{中文简称}.html
│ ├── appendix.html / 99-backpage.html
├── research/ # 调研资料
├── output/ # {title}-v{version}.html/.pdf
└── versions/ # 历史PDF存档
{项目目录}/research/YYYY-MM-{关键词}.md编辑项目目录下的 PROJECT.md,包含:
修改 build.js 中的 FRAGMENT_ORDER。与用户确认大纲后进入写作。
多Agent并行,每个agent输出一个HTML片段。
每个写作agent需要:
<html><head><style> 标签,只写正文内容)每个正文片段必须遵循以下结构,否则PDF排版会出错:
<div class="content">
<h2 class="section-title page-break" id="partN"><span class="num">§0N</span> 标题</h2>
<p class="section-en">English Title</p>
<p class="section-intro">概述</p>
<!-- 正文 -->
</div>
三条规则:
<div class="content"> 包裹 → 控制左右边距(没有它内容顶边)id="partN" 属性 → 目录锚点跳转需要page-break class → 每章从新页开始目录片段使用 .toc + .toc-item + <a href="#partN"> 结构。详见 design-system.md。
封面和尾页支持自定义作者信息,在 version.json 中配置:
{
"title": "手册标题",
"author": {
"name": "作者名称",
"title": "作者头衔/简介",
"bio": "详细简介(显示在尾页)",
"subtitle": "副标题",
"exclusive": "专属内容说明(封面底部)",
"qrImage": "二维码图片路径",
"linkUrl": "链接地址",
"linkText": "链接文字",
"social": "社交链接(HTML格式)"
}
}
封面占位符:
{{AUTHOR_NAME}} - 作者名称{{AUTHOR_TITLE}} - 作者头衔{{AUTHOR_EXCLUSIVE}} - 专属内容说明尾页占位符:
{{BOOK_TITLE}} - 手册标题{{BOOK_SUBTITLE}} - 副标题{{AUTHOR_NAME}} - 作者名称{{AUTHOR_BIO}} - 作者简介{{AUTHOR_QR_IMAGE}} - 二维码图片{{AUTHOR_LINK_URL}} - 链接地址{{AUTHOR_LINK_TEXT}} - 链接文字{{AUTHOR_SOCIAL}} - 社交链接{{VERSION}} - 版本号{{YEAR}} - 年份详细模板见 design-system.md 和 templates/fragments/
node build.js # 合并片段 → HTML
node build-pdf.js # Playwright → PDF
# 或一键:
./update.sh build # 仅构建
修改 fragments/*.html 后运行:
./update.sh patch "修正某个错误" # 1.0.0 → 1.0.1
./update.sh minor "更新内容" # 1.0.0 → 1.1.0
./update.sh major "新增章节" # 1.0.0 → 2.0.0
自动:更新version.json → 写CHANGELOG → build HTML(版本号注入封面)→ 生成PDF → 备份到versions/
bash scripts/init-project.sh <目录> <标题> 创建项目FRAGMENT_ORDER./update.sh minor "初版" 构建