直接输出html 打出的文件名为xls(excel) 就行了
你可以试试 把html改名xls就能用excel打开

解决方案 »

  1.   

    如果是windows系统,还是利用一个叫jxl.jar的包
    把数据写到xls文件吧,可以写数据也可以也表头、图形什么的。
    excel功能还是最强大的
    免费的纯java的有ireport(基础是jasperReoprts),你去sourceforge上下一个,看看能不能满足你的要求
      

  2.   

    也可以试试FineReport.
    http://www.finereport.com/demo.jsp.htm
      

  3.   

    JSP用中收集数据:javascript 实现输入多行动态输入在网上找了一下,只有一篇此类文章,还是php的,害得我要特意去看一下php,感觉很不好,是一种弱类型的语言,可以不声明就使用,因此,还要在每个变量前加$.不知道那些高手们为什么不谈谈自己写过报关系统等时候,一次性动态输入多行数据的经历.一般,我们用
    request.getParameter("value");
    来获得静态HTML输入的值.然后不要忘记判断是否为空,是否含有特殊字符等.还可以用
    Enumeration paramNames=request.getParameterNames();
    while(paramNames.hasMoreElements()){String paramName=(String)paramNames.nextElement();}
    来收集<input type="text" name="name"/>中的name但是我们每增加新的一行,参数名同上一行一样,那么,我们将如何获得value的值?
    这里我又去看书(servlet 和 JSP 核心编程,极好的一本书,该讲的都讲了,读明白了它servlet/JSP也就可以说精通了)p70页里面:getParameterValues()返回字符串数组,然后我们用循环判断这个字符串数组的长度,再就是获得值了:)
    request.getParameter("value");//这个最熟悉,获得文本框的值
    (Enumeration)request.getParameterNames();//获得文本框的名字
    (String[])request.getParameterValues(paramName);//获得静态html页相同的参数(多次出现)的值*************html 页 javascript 代码:
    <script language="javascript">
    function tbladdrow()
    {
            var i=lines.rows.length;
            var row = Table1.insertRow(Table1.rows.length);
            var col = row.insertCell(0);
            col.innerHTML = "<INPUT id=line["+i+"][name1] name=line"+i+"name1 SIZE=10>";
            col = row.insertCell(1);
            col.innerHTML = "<INPUT id=line["+i+"][name2]  name=line"+i+"name2 SIZE=10>";
            col = row.insertCell(2);
            col.innerHTML = "<INPUT id=line["+i+"][name3] name=line"+i+"name3 SIZE=10>";
            col = row.insertCell(3);
            col.innerHTML = "<INPUT id=line["+i+"][name4] name=line"+i+"name4 SIZE=10>";
    }
    function tbladdrows(items)
    {
            for( i = 1 ; i <= items ; i++)
            {
                    tbladdrow();
            }
    }
    function delrow()
    {
            if(lines.rows.length==0)
            {
                    return false  ;
            }
            lines.deleteRow();
    }</script>****************html页其它代码:
    <html>
      <head>
        <meta http-equiv="Content-Type" content="text/html; charset=Big5">
        <title>輸入</title>
      </head>
      <body>
     <form action="getInput.jsp">
      <DIV align=center><FONT size=2>輸入測試</FONT></DIV></TD>
        <TD width=412 bgColor=#e4e4e4>
          <TABLE id=Table1 cellSpacing=0 borderColorDark=#ffffff cellPadding=0
          width=350 align=center borderColorLight=#000000 border=1>
            <TBODY>
            <TR bgColor=#999999>
              <TH width=94><FONT size=2>參數一</FONT></TH>
              <TH width=84><FONT size=2>參數二</FONT></TH>
              <TH width=85><FONT size=2>參數三</FONT></TH>
              <TH width=77><FONT size=2>參數四</FONT></TH></TR>
            <TBODY id=lines name="lines"><!--
             <TR>
                 <TD><INPUT id="things_name" TYPE="text" NAME="things_name" SIZE="15"></TD>
                 <TD><INPUT id="things_model" TYPE="text" NAME="things_model" SIZE="10"></TD>
                 <TD><INPUT id="things_number" TYPE="text" NAME="things_number" SIZE="5"></TD>
                 <TD><input id="things_unit" type="text" name="things_unit" size="5"></TD>
             </TR>
                             --></TBODY></TABLE>
          <DIV align=center><BR></DIV>
          <DIV align=center>
          <INPUT id=items type=hidden value=1 name=items> <INPUT onclick=tbladdrow(items.value);type=button value=新增一行 name=insert/>
          <font color="#e4e4e4"> </font>&nbsp;&nbsp;
          <INPUT language=javascript onclick="return delrow()" type=button value=刪除一行 name=del/>
          </DIV></TD></TR></TBODY></TABLE>
    <input type="submit" value="commit"/>
    </form>
      </body>
    </html>***jsp页收集输入
    <%@ page contentType="text/html;charset=Big5"%>
    <%@ page import="java.util.*"%><%
    request.setCharacterEncoding("big5");Enumeration paramNames=request.getParameterNames();
    String paramName=null;
     while(paramNames.hasMoreElements()){
     paramName=(String)paramNames.nextElement();
     
     String param=request.getParameter(paramName);
     
     //out.println(paramName+"   "+param+"<br>");
     
      String paramValues[]=request.getParameterValues(paramName);
      for(int i=0; i<=paramValues.length-1; i++)
     {
     out.println(paramName+"  ");
     out.println(paramValues[i]+"<br>");}
     
     }
      
    //out.println("<br>"+name);%>
    <html>
      <head>
        <meta http-equiv="Content-Type" content="text/html; charset=Big5">
        <title>接受輸入</title>
      </head>
      <body>
      </body>
    </html>
      

  4.   

    http://blog.csdn.net/sylmoon/archive/2005/04/13/345948.aspx