如何将jsp页面的table报表转换到excel报表导出
来源:互联网 发布:医生转行知乎 编辑:程序博客网 时间:2024/05/16 18:04
(本文只用于导出前台已有的表格)
假设这就是你的jsp页面:
我们会添加一个“导出到excel”的超链接,它会把页面内容导出到excel文件中。那么这个页面会变成这个样子:
本篇教程我们会看到如何把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>
下面是新版本的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>
导出网页到excel代码解释:
1) 在这个版本的jsp页面中,当你点击“导出到excel”超链接的时候,请求会发送到相同的页面(excel.jsp),但是伴随url参数是 exportToExcel=YES.
<a href="excel.jsp?exportToExcel=YES">Export to Excel</a>
2) JSP页面一开始会检查参数的正确性。如果这个参数值是YES的话,我们就会看到响应报文中的内容类型,它标识了excel的文件名,并且会在用户的电脑上打开。
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"); }
3) 当你点击“导出到excel”超链接的时候,所有页面的内容会被导出excel中。但是,我们可能不想让“导出到excel”的超链接出现在excel中。为了阻止它的出现,我们增加了一个判断条件,判断exportToExcel参数是否出现。如果出现,就意味着内容会被导出到excel中,而且不包括超链接。反之,就意味着我们只是想浏览器显示网页,那么超链接会出现在页面上。
<% if (exportToExcel == null) {%><a href="excel.jsp?exportToExcel=YES">Export to Excel</a><% }%>
导出页面到excel的显示
但你点击超链接,会弹出一个对话框,问你是否打开或保存文件。点击打开,你会看到下面的内容:
正如你所看得,导出的文件也会保存你在页面上的格式设置。
如果乱码的话,请将编码格式转换为UTF-8
如果需要看关于word的导出:http://blog.csdn.net/a_as31243qadfg/article/details/52251627
- 如何将jsp页面的table报表转换到excel报表导出
- 将jsp页面的table报表转换到excel报表导出
- 利用poi从jsp页面导出报表到excel
- 利用poi从jsp页面导出报表到excel
- 利用poi从jsp页面导出报表到excel
- 利用poi从jsp页面导出报表到excel
- 利用poi从jsp页面导出报表到excel
- 将报表导出到 excel 表
- 将ASP生成的报表导出到EXCEL文件
- 将ASP生成的报表导出到EXCEL文件
- 如何将PB的交叉报表转换成EXCEL形式
- 简单的excel报表导出(jsp中)
- Excel报表的导出
- jsp页面将数据导出到Excel
- jsp页面将数据导出到Excel
- 水晶报表导出到Excel
- java 导出报表到excel
- C# 将DataGridView控件内容导出到Excel报表
- cxf3.1.7 + wss4j开发应用
- django 模板加载优化
- BFS 闯迷宫
- POJ-1251 HDU-1301 (最小生成树)
- 动作游戏战斗系统设计综述
- 如何将jsp页面的table报表转换到excel报表导出
- 文件、目录操作
- android 自动弹出软键盘(输入键盘)
- PAT-B 1002. 写出这个数 (20) Stupid!
- ios7,viewcontroller, edgesForExtendedLayout
- 监听手机电话状态改变的两种方法
- java中的修饰符以及作用范围详解图解
- java异常Exception
- 解决ThinkPHP错误Undefined class constant 'MYSQL_ATTR_INIT_COMMAND'