1. 在word或excel中制作报表的样式。
excel的行高和列宽单位无法用mm或cm表示。
需要计算。在1024*768下,1cm约为38像素。
以此为基准,可计算并控制报表的行列位置。
2. 在word中设置“表格——标题行重复”。
在excel中设置“文件——页面设置——工作表——打印标题”。
3. 另存为网页,改后缀名“htm”为“jsp”。
4. word报表文件头为:
<%@page contenttype="application/msword;charset=gbk" language="java"%>
excel报表文件头为:
<% @page contenttype="application/vnd.ms-excel;charset=gbk" language="java"%>
5. 在文件头部分定义打印参数变量如下(以excel为例):
<%
//需要打印的记录条数
int printrowcount=rowcount;
//每页打印的记录条数
int pagerowcount=16;
//最后一页需要打印的空行的数目
int loopnum=pagerowcount-printrowcount%pagerowcount;
//打印区域的高度,其中2的意思是每页需要重复的标题行的数目
int printareaheight=(printrowcount%pagerowcount==0)?printrowcount+2:printrowcount+loopnum+2;
%>
6. 在<style></style>后,改动<!--[if gte mso 9]与<![endif]-->标签中的xml标签内容,主要是设置动态打印区域(以excel为例):
<%
out.print(" ......
"<x:excelname>"+
"<x:name>print_area</x:name>"+
"<x:sheetindex>1</x:sheetindex>"+
"<x:formula>=sheet1!$a$1:$g$"+printareaheight+"</x:formula>"+
"</x:excelname>"+
...... ");
%>
7. jsp其他编码。
下面是主体循环打印部分(以excel为例):
<%
for (int i=1;i<=printrowcount; i++)
{
out.print("<tr>"<td>"+i+"</td></tr>"); //有内容
}
if (loopnum!=pagerowcount) //有空行则打印空行补齐最末一页
for (int j=1;j<=loopnum; j++)
{
out.print("<tr><td> </td></tr>");//无内容
}
%>
8. 测试并继续修改。
jrq
2005.10.21 凌晨于广州
Java Asp PHP .Net XML C/C++ CGI VB Jsp J2ee J2se J2me EJB Servlet Tomcat Resin Struts Weblogic Eclipse ANT GUI JMS Web servise IDEA Webphere Hibernate Spring Jboss Applet Swing Socket Javamail Perl Ajax P2P 安全 模式 框架 测试 开源 游戏
Windows XP Windows 2000 Windows 2003 Windows Me Windows 9.x Linux UNIX 注册表 操作系统 服务器 应用服务器