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

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

创新互联-专业网站定制、快速模板网站建设、高性价比富宁网站开发、企业建站全套包干低至880元,成熟完善的模板库,直接使用。一站式富宁网站制作公司更省心,省钱,快速模板网站建设找我们,业务覆盖富宁地区。费用合理售后完善,10多年实体公司更值得信赖。

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

网站栏目:使用JSP打印报表(Word,Excel)
文章转载:http://www.gawzjz.com/qtweb2/news15/20415.html

网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联