---最近在用itext写pdf报告,期间遇到目录生成的问题,而目录生成我认为最关键的是获取章节的页码问题。下面分别介绍这两种方法。除了这两种方法之外,还可以参考我的另一篇博客:ITEXT 目录生成的第三种方法
---前言:为了能唯一定位每个章节的页码,章节都是通过图片贴在PDF上的,即正文里的目录章节内容是图片格式。
---方法一:
-------1、先生成不带目录的PDF文件,命名为a.pdf。假设此时目录应该在第3页,分别从a.pdf中截取pdf文件,分别命名为a-start.pdf、a-end.pdf。
-------2、遍历a.pdf获取目录章节的页码。命名为a-middle.pdf。
-------3、合并a-start.pdf、a-middle.pdf、a-end.pdf三个PDF。
-------复杂度:O(M*N) M为a.pdf页数、N为目录中章节的数目。
---方法二:
-------1、先生成不带目录的PDF文件,并用Map记录目录中章节出现的页码,命名为a.pdf。假设此时目录应该在第3页,分别从a.pdf中截取pdf文件,分别命名为a-start.pdf、a-end.pdf。
-------2、直接从Map集合中获取目录章节的页码。命名为a-middle.pdf。
-------复杂度:O(N) M为a.pdf页数、N为目录中章节的数目。
-------分析:第二种方法本质上利用空间换时间来减少时间复杂度。具体源码详见itext生成目录源码
本文介绍了使用IText生成PDF报告时两种不同的目录生成方法,包括通过图片定位章节及利用空间换时间降低复杂度的技术细节。
2432

被折叠的 条评论
为什么被折叠?



