word+freemarker+itext+flyingsaucer通过模板生成pdf注意事项

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了word+freemarker+itext+flyingsaucer通过模板生成pdf注意事项相关的知识,希望对你有一定的参考价值。

参考技术A 1、通过将word另存为html中要注意

a、flying不能识别用tab来代表的空格。

b、生成的table应该删除widh属性,保留style里面的width定义。

c、在表格内的中文如果过长,将表格撑开,需要添加以下内容,这个时候就要保留table的width定义。

table

border:1px solid #000;

table-layout:fixed;

word-break:break-strict;



table td

border:1px solid #000;

word-wrap:break-word;

word-break:break-all;



d、生成的表格会有多余的border-left,border-right等属性,那就用table tdborder:1px solid #000!important;来代替。

word-wrap:break-word 不适用于 iText 2.1.7

【中文标题】word-wrap:break-word 不适用于 iText 2.1.7【英文标题】:word-wrap:break-word is not working with iText 2.1.7 【发布时间】:2012-07-30 01:04:01 【问题描述】:

我正在使用 JavaItext2.1.7 来生成 pdf,并且我编写了以下 HTML。但是太长也不是断词。

String td ="<td colspan=\"2\" align=\"left\" style=\"table-layout: fixed;word-wrap:break-word;white-space: normal;\"><b>"
                    + verylongwordverylongwordverylongword + ":</b></td>"

谁能帮我实现这个目标?

【问题讨论】:

break-word 是一个 css3 属性。从html转换时iText是否完全支持css3,由于文档关闭而很难分辨 感谢@Woody,由于您的评论,我实际上知道 IText 不支持断词。 【参考方案1】:

Itext 2.7.1 不支持 word-wrap : break-word 属性。以下是该链接。

http://demo.itextsupport.com/xmlworker/itextdoc/flatsite.html

所以我根据表格的列数手动拆分单词,并假设最大字母在 60-65 左右。以下是代码。

public String getBrokenWordsForPdfGeneration(String longString, int cutIndex)
       StringBuffer mainStringBuffer = new StringBuffer(longString);
       String returnString = "";
       while(mainStringBuffer != null && mainString.length()>0 &&                              
mainString.subString(0,mainString.length()>cutIndex?cutIndex:mainString.length()) != null) 
          if(mainStrig.subString(0,mainString.length()>cutIndex:mainString.length()).trim().contains(" "))
               returnString += mainStrig.subString(0,mainString.length()>cutIndex:mainString.length()).trim();
               mainStringBuffer.delete(0,mainString.length()>cutIndex:mainString.length());
          else
              returnString += mainStrig.subString(0,mainString.length()>cutIndex:mainString.length()).trim()+ " ";
              mainStringBuffer.delete(0,mainString.length()>cutIndex:mainString.length());
          
    
    return returnString;

【讨论】:

以上是关于word+freemarker+itext+flyingsaucer通过模板生成pdf注意事项的主要内容,如果未能解决你的问题,请参考以下文章

java使用freemarker 生成word文档

freemark在linux上生成word以后,怎么转pdf

Java Web项目中使用Freemarker生成Word文档

Java使用Flying Saucer实现HTML代码生成PDF文档

Freemarker+IText生成pdf文件

网页表单导出word和pdf格式