Affinity Publisher不支持直接导出书签,需通过四种间接方式实现:一、导出为带书签PDF后用Acrobat导出文本;二、用Acrobat JavaScript脚本批量解析;三、解压.afpub文件提取XML中书签元数据;四、用FreePic2Pdf基于目录页重建并导出书签。

如果您在Affinity Publisher中已为文档创建了书签结构,但需要将这些书签导出为外部可读格式(如文本列表或用于迁移至其他PDF阅读器),则需借助间接方式实现。Affinity Publisher本身不提供原生“导出书签”功能,但可通过文档结构导出、PDF中间转换及脚本辅助等路径达成目标。以下是可行的操作方法:
一、通过导出为带书签的PDF再提取
Affinity Publisher在导出PDF时支持嵌入交互式书签(前提是已在文档中正确设置了章节锚点与导航层级)。导出后的PDF可被第三方工具识别并反向提取书签结构。
1、在Affinity Publisher中确保所有书签已绑定至对应页面或对象:选中文本框或图形,在右侧面板选择“交互”→“添加书签”,并设置层级与跳转目标。
2、点击文件 → 导出 → 选择PDF格式,在导出选项中勾选“包含书签”和“保留交互性”。
3、使用Adobe Acrobat Pro打开该PDF,进入书签面板,右键选择“导出书签到文本…”,保存为UTF-8编码的.txt文件。
4、打开导出的文本文件,可见层级缩进格式(如一级标题无缩进、二级标题含一个Tab、三级含两个Tab),页码与标题以Tab分隔。
二、利用JavaScript脚本从PDF中批量解析书签
当需处理多个Affinity Publisher导出的PDF且要求自动化提取时,可借助Acrobat内置JavaScript控制台执行批量解析脚本,将书签树逐层遍历并写入CSV或TXT。
1、在Adobe Acrobat Pro中打开任一含书签的PDF,按Ctrl+J调出JavaScript控制台。
2、粘贴以下脚本片段(仅适用于Acrobat Pro桌面版):
3、执行脚本后,系统将弹出保存对话框,提示将书签结构导出为纯文本文件。
4、该脚本可识别多级嵌套、跳转页码及目标标题,并自动保留缩进层级关系,适用于50页以上含复杂目录的出版物。
三、通过XML结构导出间接获取书签元数据
Affinity Publisher项目文件(.afpub)本质为ZIP压缩包,内部包含描述文档结构的XML文件。若书签已作为锚点或交互对象定义,其坐标与命名可能存在于interactions.xml或document.xml中。
1、将.afpub文件后缀改为.zip,使用解压工具打开。
2、定位至Contents/interactions.xml或Contents/document.xml路径。
3、搜索关键词"bookmark"或"destination",查找带有page属性与name属性的节点。
4、手动提取匹配节点中的name值(标题名)与page值(目标页码),整理为表格格式。
5、此方法适用于技术文档作者需审计书签配置完整性,但不支持自动导出层级关系。
四、使用FreePic2Pdf反向生成标准书签文本
若原始PDF由Affinity Publisher导出且未嵌入完整书签,但文档前部存在规范目录页(含标题与页码),可借助FreePic2Pdf的目录识别功能重建并导出结构化书签文本。
1、使用OCR工具(如Adobe Scan或ABBYY FineReader)对PDF目录页进行文字识别,输出为可编辑TXT。
2、在Notepad++中打开TXT,使用正则表达式将“1.1 简介 3”格式统一为“1.1\t简介\t3”,确保每行仅含一个标题、一个Tab、一个页码。
3、启动FreePic2Pdf,选择“更改PDF→往PDF挂书签”,导入该TXT文件,软件将自动生成符合PDF标准的书签树。
4、再次导出PDF后,即可用Acrobat执行“导出书签到文本”操作,完成批量导出流程。











