我有一个HTML(而不是XHTML)文档,可以在Firefox3和IE7中显示良好。它使用相当基本的CSS来设置样式,并在HTML中呈现良好的效果。

我现在正在寻找一种将其转换为PDF的方法。我尝试过:

DOMPDF:它在表格方面存在巨大问题。我分解了我的大型嵌套表,这有助于(之前它只消耗了128M的内存,然后就死了——这是我在php.ini中的内存限制),但它把表弄得一团糟,而且似乎没有图像。这些表格只是一些基本的东西,带有一些边框样式,可以在各个点添加一些线条;HTML2PDF和HTML2PS:实际上我在这方面运气更好。它呈现了一些图像(所有图像都是Google Chart URL),表格格式要好得多,但它似乎有一些复杂性问题,我还没有弄清楚,并且一直因未知的node_type()错误而死亡。不知道从这里去哪里;和Htmldoc:这在基本的HTML上似乎很好,但几乎不支持CSS,所以你必须用HTML做所有的事情(我没有意识到在Htmldoc领域还是2001年…),所以这对我来说是无用的。

我尝试了一个名为Html2Pdf Pilot的Windows应用程序,它确实做得很好,但我需要至少在Linux上运行,最好通过Web服务器上的PHP按需运行的应用程序。

我缺少什么,或者如何解决这个问题?


当前回答

这个问题已经很老了,但还没有人提到CutyCapt,所以我会:)

可爱的卡通

CutyCapt是一个小型的跨平台命令行实用程序,用于捕获WebKit将网页呈现为各种矢量位图格式,包括SVG、PDF、PS、PNG、JPEG、TIFF、GIF和BMP

其他回答

Darryl Hein在上面提到TCPDF可能是一个好主意。Nicola Asuni的代码非常方便和强大。唯一的杀手是,如果你计划将PDF文件与生成的PDF合并,那么它就没有这些功能。您必须创建PDF,然后使用Sid Steward的PDFTK(www.pdflabs.com/tools/PDFTK the PDF toolkit/)进行合并。

为了突出线程,我尝试了DOMPDF,它工作得很好。我使用了DIV和其他块级元素来定位所有内容,我严格使用了CSS2.1,它的播放效果非常好。

尝试获取最新的夜间dompdf构建-我使用的是一个旧版本,这是一个可怕的资源占用,并花费了很长时间来渲染我的pdf。在这里度过了一个夜晚。

只花了几秒钟就生成了PDF,而且它的渲染效果与PrinceXML/Docraptor一样好。自从我上次使用dompdf代码以来,他们似乎已经认真优化了它!

Zend的devzone上有一个关于在没有任何外部库的情况下从php生成pdf的教程(第1部分,第2部分)。我从未实现过这种解决方案,但由于它都是php,所以您可能会发现它更灵活地实现和调试。

也许您可以在将文件交给转换器之前尝试使用Tidy。如果其中一个渲染器遇到HTML问题(如未关闭的标记),可能会有所帮助。