永发信息网

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

答案:2  悬赏:40  手机版
解决时间 2021-02-01 13:48
如何将jsp页面的table报表转换到excel报表导出
最佳答案
无非是这样的一个过程。先通过数据库查询出数据,放到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 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
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,你可以下载一个。希望能帮到你,欢迎追问。望采纳!
全部回答
在jsp页面上面加一句: <%@ page contenttype="application/vnd.ms-excel;charset=iso-8859-1" %> 数据直接写成html表格就可以了。 如果有中文问题,就把charset=iso-8859-1改成gb2312试试
我要举报
如以上问答信息为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
大家都在看
中国建设银行24小时自助银行(云平路)地址在哪
临沭县至汤河镇龙窝村有车吗?龙窝村到板泉镇
关于第二次机器人大战PS版的问题
在电缆敷设过程中,应做的工作包括()。A.标明
中国建设银行24小时自助银行(云漳路)地址好找
企业购房可以贷款吗
验梦的意思是什么啊?知道的请说下!
中国信合24小时自助银行(莆政路)地址有知道的
【金波简介】金波 盲孩子和他的影子简述课文
ps怎么画斜的网格线,类似下面的那样​
sb 265 gr.1什么意思
这样的。我单位机票报销的,但我只拿了登记票
中国农业银行ATM(云东路)地址在什么地方,我
乞教的意思是什么啊?知道的请说下!
11月18日汝南科级干部喝酒死人
推荐资讯
生完孩子快一百天了要吃什么药
意头的近义词是什么
Trek(崔克)十堰专卖店地址好找么,我有些事要
我的电脑是宏基3820的,硬盘500G ,用acronis
夏威夷游泳娱乐中心地址好找么,我有些事要过
华兴宾馆(东升中路)地址好找么,我有些事要过
【温度计量体温多长时间】用温度计量体温多长
台球地址在什么地方,我要处理点事
是否有一种潮汕话叫 岛窝金钱的鱼胶'谐
旭旭超市地址在哪,我要去那里办事
速递易(沙滨路66号秋水长天8号楼速递易)地址
葐蒀的意思是什么啊?知道的请说下!
正方形一边上任一点到这个正方形两条对角线的
阴历怎么看 ?