怎么把jsp页面表单上的数据导出成Excel-CSDN论坛

如题所述

无非是这样的一个过程。先通过数据库查询出数据,放到List里,然后把这个List发往页面,然后遍历这个List把数据显示到这个表格里。 要想把数据导出到execel,很简单,把页面接受的这个List用jxl写到Execel就行了。具体将List导出到Execel的类如下:

package cms.dao;
import java.io.IOException;
import java.io.OutputStream;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.util.List;
import javax.servlet.http.HttpServletResponse;
import jxl.Workbook;
import jxl.write.WritableSheet;
import jxl.write.WritableWorkbook;
import cms.utlis.DbUtils;
public class ToExecelByQuery {
//方法接受两个参数,一个是list,这个地方我用了泛型。另一个参数是HttpServletResponse response
public static void toExcelBy(List<AccessLog> list,HttpServletResponse response) {
// 创建工作表
WritableWorkbook book=null;
response.reset();
// 创建工作流
OutputStream os =null;
try {
// 设置弹出对话框
response.setContentType("application/DOWLOAD");
// 设置工作表的标题
response.setHeader("Content-Disposition",
"attachment; filename=****.xls");//设置生成的文件名字
os = response.getOutputStream();

// 初始化工作表
book = Workbook.createWorkbook(os);

} catch (IOException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
}
try{
//以下是我做的导出日志的一个模版
int nCount = list.size();
WritableSheet sheet = book.createSheet("访问日志", 0);
// 生成名为"商品信息"的工作表,参数0表示这是第一页
int nI = 1;
// 表字段名
sheet.addCell(new jxl.write.Label(0, 0, "日志编号"));
sheet.addCell(new jxl.write.Label(1, 0, "用户ID"));
sheet.addCell(new jxl.write.Label(2, 0, "用户姓名"));
sheet.addCell(new jxl.write.Label(3, 0, "访问日期"));
sheet.addCell(new jxl.write.Label(4, 0, "访问时间"));
sheet.addCell(new jxl.write.Label(5, 0, "名片ID"));
sheet.addCell(new jxl.write.Label(6, 0, "名片名称"));
sheet.addCell(new jxl.write.Label(7, 0, "创建日期"));
sheet.addCell(new jxl.write.Label(8, 0, "更新日期"));
// 将数据追加
for(int i=1;i<list.size();i++){

sheet.addCell(new jxl.write.Label(0, i, list.get(i).toString()));
sheet.addCell(new jxl.write.Label(1, i, list.get(i).getUserId()));
sheet.addCell(new jxl.write.Label(2, i, list.get(i).getUsername()));
sheet.addCell(new jxl.write.Label(3, i, list.get(i).getCrtTim()));
sheet.addCell(new jxl.write.Label(4, i, list.get(i).getComplTime()));
sheet.addCell(new jxl.write.Label(5, i, list.get(i).getCopId()));
sheet.addCell(new jxl.write.Label(6, i, list.get(i).getFirstname()));
sheet.addCell(new jxl.write.Label(7, i, list.get(i).getCrtTim()));
sheet.addCell(new jxl.write.Label(8, i, list.get(i).getUpdTim()));

}
book.write();
book.close();
} catch (Exception e) {
e.printStackTrace();
}
}
}
大体思路就是这样的,别忘了在你的项目中导入JXL必要的jar包,这个包叫jxl.jar,你可以下载一个。希望能帮到你,欢迎追问。望采纳!
温馨提示:内容为网友见解,仅供参考
第1个回答  2016-09-20
留个QQ,发给你个控件

怎么把jsp页面表单上的数据导出成Excel-CSDN论坛
\/\/方法接受两个参数,一个是list,这个地方我用了泛型。另一个参数是HttpServletResponse response public static void toExcelBy(List<AccessLog> list,HttpServletResponse response) { \/\/ 创建工作表 WritableWorkbook book=null;response.reset();\/\/ 创建工作流 OutputStream os =null;try { \/\/ 设...

jsp如何利用POI直接生成Excel并在页面中导出
1、修改WEB服务器的CONF\/web.xml,添加 <mime-mapping> <extension>xls<\/extension> <mime-type>application\/vnd.ms-excel<\/mime-type> <\/mime-mapping> 如果不添加这个,那么在网页中下载的时候就变成了JSP文件 2、download.jsp文件 <%@ page contentType="application\/vnd.ms-excel" language="jav...

JSP表单高手来帮忙下,谢谢!
name一样和不一样处理数据的jsp写法就不一样。如果name都一样:就要用request.getparameters(); 注意后面有个s 如果不一样就要用一个隐藏input将数量传到处理页 第二个问题:你说的那个RMB,HKD,USD是要选择的,处理的时候根据选择的不同执行不同的操作,但是看你的处理jsp根本就没有做判断。首先...

网页提交表单的求助!!!
提交必须动态语言 asp jsp php cgi都可以 后台就需要数据库 常用的mysql之类的 免费好用就行 但是静态html不行 这个问题这里没那么容易说清楚的 最好找本书看看才能明白的

JSP怎么将表单提交到对应的servlet
1. 用于登录的jsp页面,其中有一个form表单用于提交用户名和密码 2. 创建一个名为LoginServlet的Servlet,下面是doGet与doPost部分 3. 配置web.xml,这是最关键的一步 需要注意的是url-pattern这里写的是\/login,而在jsp中form表单的action写的是login,而不是\/login,因为尝试了其他写法都...

jsp文件到底要不要加No-cache-CSDN论坛
当然多运用CSS也会减少html的代码 我图片不是很多,而且还都是那种小图标,都是几百B,几K的,不会很大,数据库执行就几十ms不要1s的时间,可是等到界面完全加载完就得等好几秒钟,有时甚至一、二十秒 有的页面表单内容很多,有的页面很少。隐藏域也很多,这是没办法的了。业务需要。

jsp怎样实现页面登录验证数据库里面的内容
解决方案一:登录的时候根据用户名和密码去数据库查询,有就登录成功,没就提醒注册或返回登录页面 解决方案二:http:\/\/blog.csdn.net\/c0c0cf\/article\/details\/8996444 我觉得你应该找一本jsp相关开发的书籍先学一下,然后尝试着自己动手试一试。解决方案三:老师有要求书上应该有相似的例子,照着看看写...

这个JSP注册登陆页面的代码怎么写
确实,分也少,不是一段二段两的代码 找个例子去吧,CSDN 上面应该有入门级别的 兄弟,虽然你分少,但是我也不会嫌弃的,给我吧 嘿嘿

求一个编程,开发工具用的是JSP和eclipse,三层架构的
1)Jbuilder支持最新的Java技术,包括Applets、JSP\/Servlets、JavaBean以及EJB(Enterprise JavaBeans)的应用。 2)用户可以自动地生成基于后端数据库表的EJB Java类,Jbuilder同时还简化了EJB的自动部署功能.此外它还支持CORBA,相应的向导程序有助于用户全面地管理IDL(分布应用程序所必需的接口定义语言Interface Definition Lang...

java中怎么获取客户端的真实的IP-CSDN论坛
在JSP里,获取客户端的IP地址的方法是:request.getRemoteAddr(),这种方法在大部分情况下都是有效的。但是在通过了Apache,Squid等反向代理软件就不能获取到客户端的真实IP地址了。如果使用了反向代理软件,将http:\/\/192.168.1.110:2046\/ 的URL反向代理为 http:\/\/www.bt285.cn \/ 的URL时,用...

相似回答