将jsp页面内容保存到excel(转)
在此,强调一下搜索时关键词的重要性,这样一下子可以定位到文章,否则处于盲人摸象,毫无目的尴尬境地。本篇就是通过export jsp to excel找到的。
原文地址:How to Export Web Page to Excel (in JSP)?
本篇教程我们会看到如何把JSP页面导出到Excel中,会在已有的JSP页面中增加导出excel的功能。
许多时候对于用户来说,可以在excel中看到页面内容是很方便的。公共的方案会被导出成包含一些报告、数字等信息的表格。通过导出数据导出到excel中,最终用户也可以使用excel来做各种的分析,这一点对于你的java基本程序来实现,是有困难的。
假设这就是你的jsp页面:
这是对应的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>
导出网页到excel代码解释:
- <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的显示
注意:
如果没有设置:response.setHeader("Content-Disposition", "attachment; filename=" + filename+".xls");
则默认为当前页面.xls。
比如testexcel.jsp--->则生成testexcel.xls表格
扩展阅读:
[1]在JSP中通过http协议生成excel和word:作者用过jxl之后,选择了http方式生成excel
[2]JSP-EXCEL save defualt in .xls extension, open excel with in the browser:
[3]利用HTTP协议,更改输出文件:引出了HTTP1.1协议的重要性
[4]超文本传输协议-HTTP(修订版):详细解释了HTTP1.1协议
[5]Multiple tables data exported to multiple worksheets of the same excel sheet in java:一个excel中,存储在多个sheet
将jsp页面内容保存到excel(转)的更多相关文章
- jsp 页面内容导出到Excel中
日常使用网络资源时经常需要把网页中的内容下载到本地,并且导出到Excel中,现在介绍一种非常简单的方式实现网络资源的下载.只需要讲jsp的最上面加上一句话 <% response.reset() ...
- table内容保存到Excel中
@{ Layout = null; } <html> <head> <title></title> </head> <body> ...
- 将查询列表内容保存到excel表格中,并保存到相应的盘中
1.先导入相应的jar包 2.一个小的Demo测试[实体类+测试类:保存excel的方法] Student实体类 public class Student{ private int id; priva ...
- Sql数据保存到Excel文件中
public string ExportExcel( DataSet ds,string saveFileName) { try { if (ds == null) return "数据库为 ...
- 调用获取学生信息的接口,保存到excel里面
# 2.http: // doc.nnzhp.cn / index.php?s = / 6 & page_id = 14# 调用获取学生信息的接口,保存到excel里面 import requ ...
- 调用获取学生信息的接口,保存到excel里面的小程序
# 2.http: // doc.nnzhp.cn / index.php?s = / 6 & page_id = 14# 调用获取学生信息的接口,保存到excel里面 import requ ...
- 批量生成随机字符串并保存到excel
需要导入jxl.jar,commons-lang-2.6.jar 链接:https://pan.baidu.com/s/1NPPh24XWxkka68x2JQYlYA 提取码:jvj3 链接:http ...
- 用python实现批量获取Linux主机简要信息并保存到Excel中 unstable 1.1
#!/usr/bin/env python3 # -*- coding: utf-8 -*- #filename get_linux_info.py #获取Linux主机的信息 # titles=[' ...
- 用Python提取XML里的内容,存到Excel中
最近做一个项目是解析XML文件,提取其中的chatid和lt.timestamp等信息,存到excel里. 1.解析xml,提取数据 使用python自带的xml.dom中的minidom(也可以用l ...
随机推荐
- 使用Istio治理微服务入门
近两年微服务架构流行,主流互联网厂商内部都已经微服务化,初创企业虽然技术积淀不行,但也通过各种开源工具拥抱微服务.再加上容器技术赋能,Kubernetes又添了一把火,微服务架构已然成为当前软件架构设 ...
- C语言基础知识【变量】
C 变量1.变量其实只不过是程序可操作的存储区的名称.C 中每个变量都有特定的类型,类型决定了变量存储的大小和布局,该范围内的值都可以存储在内存中,运算符可应用于变量上.变量的名称可以由字母.数字和下 ...
- C语言基础知识【C语言教程】
2017年7月7日23:15:51外边下雨,突然想学习c语言,所以刷一遍基础. 笔记:C 语言教程1.C 语言是一种通用的.面向过程式的计算机程序设计语言.1972 年,为了移植与开发 UNIX 操作 ...
- 仿百度壁纸client(五)——实现搜索动画GestureDetector手势识别,动态更新搜索keyword
仿百度壁纸client(五)--实现搜索动画GestureDetector手势识别,动态更新搜索关键字 百度壁纸系列 仿百度壁纸client(一)--主框架搭建,自己定义Tab + ViewPager ...
- 图片剪裁控件——ClipImageView
这段时间在做自己的项目时,须要使用到图片剪裁功能,当时大概的思考了一些需求.想到了比較简单的实现方法.因此就抽了点时间做了这个图片剪裁控件--ClipImageView 这里先贴上ClipImageV ...
- jquery 使用笔记
一下是在做项目中用到jquery涉及到的一些知识点,把源码复制过来,省得以后忘记了: <link href="<%=request.getContextPath()%>/c ...
- 大数据学习系列(6)-- zookeeper集群搭建
下载 wget http://mirrors.shuosc.org/apache/zookeeper/zookeeper-3.3.6/zookeeper-3.3.6.tar.gz tar -zxvf ...
- 优化tomcat启动速度
1.去掉不需要的jar包,这样tomcat在启动时就可以少加载jar包里面的class文件. 2.跳过一些与TLD files.注解.网络碎片无关的jar包,通过在conf/catalina.prop ...
- data standardization
import random import numpy as np l, num, gen_min_, gen_max_ = [], 100, 1, 200 l = [random.randint(ge ...
- zabbix 主机组管理
分组的目的是将同一属性的主机归类,主机组中可以包含主机,也可以包含模板 建议:同一属性的主机或者模板,尽量归纳到分组中方便以后管理.分组原则如下: 以地理位置进行划分 以业务划分 以机器用途划分 以系 ...