如何将jsp页面的table报表转换到excel报表导出

 我来答
huanglenzhi
推荐于2016-05-02 · 知道合伙人数码行家
huanglenzhi
知道合伙人数码行家
采纳数:117538 获赞数:517170
长期从事计算机组装,维护,网络组建及管理。对计算机硬件、操作系统安装、典型网络设备具有详细认知。

向TA提问 私信TA
展开全部
  本篇教程我们会看到如何把JSP页面导出到Excel中,会在已有的JSP页面中增加导出excel的功能。

  许多时候对于用户来说,可以在excel中看到页面内容是很方便的。公共的方案会被导出成包含一些报告、数字等信息的表格。通过导出数据导出到excel中,最终用户也可以使用excel来做各种的分析,这一点对于你的java基本程序来实现,是有困难的。

  这是对应的jsp源码(导出excel功能还没有加)。一个包含简单数据表格的jsp页面。

  <%@ page language="java" contentType="text/html; charset=ISO-8859-1"
  pageEncoding="ISO-8859-1"%>
  <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
  <html>
  <head>
  <meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
  <title>Export to Excel - Demo</title>
  </head>
  <body>
  <table align="center" border="2">
  <thead>
  <tr bgcolor="lightgreen">
  <th>Sr. No.</th>
  <th>Text Data</th>
  <th>Number Data</th>
  </tr>
  </thead>
  <tbody>
  <%
  for (int i = 0; i < 10; i++) {
  %>
  <tr bgcolor="lightblue">
  <td align="center"><%=i%></td>
  <td align="center">This is text data <%=i%></td>
  <td align="center"><%=i * i%></td>
  </tr>
  <%
  }
  %>
  </tbody>
  </table>
  </body>
  </html>
  我们会添加一个“导出到excel”的超链接,它会把页面内容导出到excel文件中。那么这个页面会变成上图。

  下面是新版本的jsp源码。这个版本增加了“导出到excel”超链接,而且增加了相应的功能:

  <%@ page language="java" contentType="text/html; charset=ISO-8859-1"
  pageEncoding="ISO-8859-1"%>
  <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
  <html>
  <head>
  <meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
  <title>Export to Excel - Demo</title>
  </head>
  <body>
  <%
  String exportToExcel = request.getParameter("exportToExcel");
  if (exportToExcel != null
  && exportToExcel.toString().equalsIgnoreCase("YES")) {
  response.setContentType("application/vnd.ms-excel");
  response.setHeader("Content-Disposition", "inline; filename="
  + "excel.xls");
  
  }
  %>
  <table align="left" border="2">
  <thead>
  <tr bgcolor="lightgreen">
  <th>Sr. No.</th>
  <th>Text Data</th>
  <th>Number Data</th>
  </tr>
  </thead>
  <tbody>
  <%
  for (int i = 0; i < 10; i++) {
  %>
  <tr bgcolor="lightblue">
  <td align="center"><%=i + 1%></td>
  <td align="center">This is text data <%=i%></td>
  <td align="center"><%=i * i%></td>
  </tr>
  <%
  }
  %>
  </tbody>
  </table>
  <br><br><br><br><br><br><br><br><br><br><br><br><br><br><br>
  
  <%
  if (exportToExcel == null) {
  %>
  <a href="excel.jsp?exportToExcel=YES">Export to Excel</a>
  <%
  }
  %>
  </body>
  </html>
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式