PDF文件结构

简介: PDF文件结构

pdf(Portable Document Format的简称,意为“便携式文档格式”),是由Adobe Systems用于与应用程序、操作系统、硬件无关的方式进行文件交换所发展出的文件格式

PDF文件结构四个部分

  1. 文件头 Header
  2. 文件体 Body
  3. 交叉引用表 Cross-reference table
  4. 文件尾 Trailer

更新方式:采用增量更新

PDF文件支持8种基本类型对象

  1. 布尔
true和false
  1. 整数和实数
549
  1. 字符串
(This is a string)  % 可见字符
<4E6F762073686D6F7A206B6120706F702E>  % 16进制
  1. 名称
/Type
  1. 数组
[549 3.14false (Ralph) /SomeName]
  1. 字典
<</Type /Example
/StringItem(a string)
/Subdictionary<< /Item1 0.4
/Item2true
/LastItem(not!)
/VeryLastItem(OK)
>>
>>
  1. 流对象
stream
流资料
Endstream
  1. 空对象
以null来表示

各种对象的辨识方法

(1) 以(开头:字符串对象


(2) 以/开头:名称对象


(3) 以<开头:若后面不接<,便是字符串对象(见<<开头的说明)


(4) 以<<开头:词典对象,若之后再接stream便是流对象


(5) 以负号开头:后面接数字便是数字对象


(6) 以数字开头:数字对象,整数对象必须再往后看两个对象,才能决定是否为对象参用形式


(7) 以f开头:若是false便是布尔对象


(8) 以n开头:若是null便是空对象


(9) 以t开头:若是true便是布尔对象


(10) 以[开头:数组对象


(11) 其他:不合法的对象

1、首部

%PDF-1.4 

PDF文件格式版本号

2、文件体

3 0 obj
<<
/Type /Pages
/Count 1
/Kids [4 0 R]
>>
endobj

对象号, 唯一标识一个对象 eg: 3

产生号, 修改次数 eg: 0

对象内容, 包含在<< 和>>之间 以关键字endobj结束

3、交叉引用表

用来索引各个obj 对象在文档中的位置,以实现随机访问

xref
0 8
0000000000 65535f
0000000009 00000n
0000000074 00000 n
0000000120 00000 n
0000000179 00000 n
0000000322 00000 n
0000000415 00000 n
0000000445 00000 n

解释:

  • xref:交叉引用表的开始
  • 第一行0 8: 下面各行所描述的对象号是从0开始,并且有8个对象
  • 0000000000 65535f:

(1) 对象0的起始地址为0000000000,产生号(generation number)为65535

(2) 65535是最大产生号,不可以再进行更改

(3) f:对象为free

(4) 一般每个PDF文件都是以这一行开始交叉应用表,其实这个对象可以看作是文件头

  • 0000000009 00000n:

(1) 表示对象1,0000000009是其偏移地址,

(2) 00000为5位产生号(最大为65535),0表明该对象未被修改过,

(3) n表示该对象在使用,区别与自由对象(f),可以更改。

4、尾部

Trailer
<<
/Size 8
/Root 1 0 R
>>
startxref
553
%%EOF

解释

(1)trailer 说明文件尾 trailer对象的开始

(2)/Size 8 说明该PDF文件的对象数目

(3)/Root 1 0 R 说明根对象的对象号为1

(4)Startxref 553说明交叉引用表的偏移地址,从而可以找到PDF文档中所有的对象的相对地址,进而访问对象。

(5)%%EOF 为文件结束标志

参考

  1. https://baike.baidu.com/item/pdf/317608
  2. PDF学习二:PDF文件物理结构
  3. PDF文档结构说明
相关文章
|
8月前
|
存储 JSON API
如何将 Swagger 文档导出为 PDF 文件
你会发现自己可能需要将 Swagger 文档导出为 PDF 或文件,以便于共享和存档。在这篇博文中,我们将指导你完成将 Swagger 文档导出为 PDF 格式的过程。
|
5月前
|
C#
【PDF提取内容改名】批量提取PDF指定区域内容重命名PDF文件,PDF自动提取内容命名的方案和详细步骤
本工具可批量提取PDF中的合同编号、日期、发票号等关键信息,支持PDF自定义区域提取并自动重命名文件,适用于合同管理、发票处理、文档归档和数据录入场景。基于iTextSharp库实现,提供完整代码示例与百度、腾讯网盘下载链接,助力高效处理PDF文档。
687 40
|
5月前
|
编译器 Python
如何利用Python批量重命名PDF文件
本文介绍了如何使用Python提取PDF内容并用于文件重命名。通过安装Python环境、PyCharm编译器及Jupyter Notebook,结合tabula库实现PDF数据读取与处理,并提供代码示例与参考文献。
|
7月前
|
人工智能 算法 安全
使用CodeBuddy实现批量转换PPT、Excel、Word为PDF文件工具
通过 CodeBuddy 实现本地批量转换工具,让复杂的文档处理需求转化为 “需求描述→代码生成→一键运行” 的极简流程,真正实现 “技术为效率服务” 的目标。感兴趣的快来体验下把
305 10
|
6月前
|
数据采集 存储 API
Python爬虫结合API接口批量获取PDF文件
Python爬虫结合API接口批量获取PDF文件
|
10月前
|
人工智能 编解码 文字识别
OCRmyPDF:16.5K Star!快速将 PDF 文件转换为可搜索、可复制的文档的命令行工具
OCRmyPDF 是一款开源命令行工具,专为将扫描的 PDF 文件转换为可搜索、可复制的文档。支持多语言、图像优化和多核处理。
1085 17
OCRmyPDF:16.5K Star!快速将 PDF 文件转换为可搜索、可复制的文档的命令行工具
|
11月前
|
机器学习/深度学习 人工智能 文字识别
Zerox:AI驱动的万能OCR工具,精准识别复杂布局并输出Markdown格式,支持PDF、DOCX、图片等多种文件格式
Zerox 是一款开源的本地化高精度OCR工具,基于GPT-4o-mini模型,支持PDF、DOCX、图片等多种格式文件,能够零样本识别复杂布局文档,输出Markdown格式结果。
1001 4
Zerox:AI驱动的万能OCR工具,精准识别复杂布局并输出Markdown格式,支持PDF、DOCX、图片等多种文件格式
|
10月前
|
文字识别 Serverless 开发工具
【全自动改PDF名】批量OCR识别提取PDF自定义指定区域内容保存到 Excel 以及根据PDF文件内容的标题来批量重命名
学校和教育机构常需处理成绩单、报名表等PDF文件。通过OCR技术,可自动提取学生信息并录入Excel,便于统计分析和存档管理。本文介绍使用阿里云服务实现批量OCR识别、内容提取、重命名及导出表格的完整步骤,包括开通相关服务、编写代码、部署函数计算和设置自动化触发器等。提供Python示例代码和详细操作指南,帮助用户高效处理PDF文件。 链接: - 百度网盘:[链接](https://pan.baidu.com/s/1mWsg7mDZq2pZ8xdKzdn5Hg?pwd=8866) - 腾讯网盘:[链接](https://share.weiyun.com/a77jklXK)
1250 5
|
12月前
|
人工智能 文字识别 数据挖掘
MarkItDown:微软开源的多格式转Markdown工具,支持将PDF、Word、图像和音频等文件转换为Markdown格式
MarkItDown 是微软开源的多功能文档转换工具,支持将 PDF、PPT、Word、Excel、图像、音频等多种格式的文件转换为 Markdown 格式,具备 OCR 文字识别、语音转文字和元数据提取等功能。
2524 9
MarkItDown:微软开源的多格式转Markdown工具,支持将PDF、Word、图像和音频等文件转换为Markdown格式
|
12月前
|
JavaScript
jquery图片和pdf文件预览插件
EZView.js是一款jquery图片和pdf文件预览插件。EZView.js可以为图片和pdf格式文件生成在线预览效果。支持的文件格式有pdf、jpg、 png、jpeg、gif。
337 16

热门文章

最新文章