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

开发 后端
本文讲述JSP打印报表的一种简单的方法。文章介绍如何把Word或Excel文档另存为JSP文件,并使用JSP代码控制报表打印。

使用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打印报表并继续修改。

【编辑推荐】

  1. 简单介绍JSP技术
  2. JSP技术入门学习
  3. ASP和JSP页面简单介绍
  4. 用JSP程序打造一个留言板
  5. 如何成为一个优秀的JSP程序员
责任编辑:yangsai 来源: 网络
相关推荐

2024-07-15 15:05:20

Python数据驱动

2009-07-02 13:18:53

JSP打印报表

2009-05-21 10:08:49

SQL报表JSPHibernate

2009-07-06 16:17:36

生成PDF报表JSP页面

2021-05-16 07:08:18

ExcelWord技巧

2021-04-17 23:10:59

Python微软Word

2018-08-02 21:28:00

软件

2011-05-04 14:00:02

打印机Word打印

2011-05-04 09:56:54

打印机Word打印

2018-01-18 16:40:02

润乾word报表

2023-10-18 13:57:17

2009-07-04 00:50:38

2009-07-02 11:34:42

JSP指令JSP开发

2009-06-06 18:43:34

JSP Action

2009-09-10 09:48:15

JSP使用FCKedi

2009-03-16 15:07:20

JSP分页window.openJSP表单

2009-08-12 18:19:46

ASP.NET报表打印

2011-06-21 17:09:31

打印机技巧

2009-07-06 15:31:42

JSP Action

2011-07-05 12:32:30

打印机解决方案
点赞
收藏

51CTO技术栈公众号