转载

使用JSP打印报表(Word,Excel)

使用JSP打印报表(Word,Excel等)可以使用如下方法:

1. 需要计算。在1024*768下,1CM约为38像素。

以此为基准,可计算并控制报表的行列位置,从而决定JSP打印报表的位置。

2. 在Word中设置“表格――标题行重复”。

在Excel中设置“文件――页面设置――工作表――打印标题”。

3. 另存为网页,改后缀名“htm”为“jsp”。

4. Word报表文件头为:

  1. <%@page contentType="application/msword;charset=GBK" language="java"%>   

Excel报表文件头为:

  1. <% @page contentType="application/vnd.ms-excel;charset=GBK" language="java"%>  

5. 在JSP文件头部分定义打印参数变量如下(以Excel为例):

  1. <%   
  2.  
  3. //需要打印的记录条数  
  4. int PrintRowCount=RowCount;   
  5.  
  6. //每页打印的记录条数  
  7. int PageRowCount=16;   
  8.  
  9. //最后一页需要打印的空行的数目  
  10. int LoopNum=PageRowCount-PrintRowCount%PageRowCount;   
  11.  
  12. //打印区域的高度,其中2的意思是每页需要重复的标题行的数目  
  13. int PrintAreaHeight=(PrintRowCount%PageRowCount==0)?PrintRowCount+2:PrintRowCount+LoopNum+2;  
  14.  
  15. %>   

6. 在<style></style>后,改动<!--[if gte mso 9]与<![endif]-->标签中的XML标签内容,主要是设置动态打印区域(以Excel为例):

  1. <%   
  2.  
  3. out.print(" ......  
  4. "<x:ExcelName>"+  
  5. "<x:Name>Print_Area</x:Name>"+  
  6. "<x:SheetIndex>1</x:SheetIndex>"+  
  7. "<x:Formula>=Sheet1!$A$1:$G$"+PrintAreaHeight+"</x:Formula>"+  
  8. "</x:ExcelName>"+  
  9. ...... ");  
  10.  
  11. %>   

7. JSP其他编码。

下面是主体循环打印部分(以Excel为例):

  1. <%   
  2. for (int i=1;i<=PrintRowCount; i++)  
  3. {  
  4. out.print("<tr>"<td>"+i+"</td></tr>"); //有内容  
  5. }  
  6.  
  7. if (LoopNum!=PageRowCount) //有空行则打印空行补齐最末一页  
  8. for (int j=1;j<=LoopNum; j++)  
  9. {  
  10. out.print("<tr><td></td></tr>");//无内容  
  11. }  
  12. %>  

8. 测试JSP打印报表并继续修改。

正文到此结束
Loading...