怎么在JSP里做使显示的数据表导出EXCEL

本文介绍了一个使用Java进行Excel文件读写的Servlet示例。该Servlet能够从数据库中获取数据,并将其填充到Excel表格中,支持根据不同参数动态生成Excel文档。文章详细展示了如何设置单元格格式、合并单元格以及处理不同类型的数据。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

[size=x-large]package com.hull.servlet;

import jxl.*;
import jxl.write.*;
import jxl.format.BorderLineStyle;
import java.io.*;
import javax.servlet.http.*;
import javax.servlet.*;
import java.sql.ResultSet;
import java.sql.SQLException;

import com.hull.db.pool.SqlServerPool;
import com.hull.tools.StringConverter;

/**
* <p>Title: hull</p>
* <p>Description: read and write excel with java</p>
* <p>Copyright: Copyright (c) 2004</p>
* <p>Company: hz-group</p>
* @author wangdong
* @version 1.0
*/

public class JExcel extends HttpServlet{
private String excelFilePath;
private WritableWorkbook wbbook;
//private FileOutputStream os;
private OutputStream os;
private WritableCellFormat wcf,wcf_title;
private WritableSheet ws;

private String title;
private int sheetid;
private long shipid;


public void init(ServletConfig config) throws ServletException{
super.init();
excelFilePath = config.getInitParameter("excelFilePath");
if(excelFilePath == null){
throw new ServletException("不能创建excel文件!");
}
}

public void doGet(HttpServletRequest request,HttpServletResponse response)
throws ServletException,IOException{
response.setContentType("application/vnd.ms-excel");
title = request.getParameter("shipname");
shipid = (new Long(request.getParameter("shipid"))).longValue();

os = response.getOutputStream();

wbbook = Workbook.createWorkbook(os);

sheetid = (wbbook.getSheets()).length;

try{
wcf = new WritableCellFormat();
wcf.setAlignment(Alignment.RIGHT);
wcf.setBorder(Border.ALL,BorderLineStyle.THIN);
wcf.setWrap(true);

wcf_title = new WritableCellFormat();
wcf_title.setAlignment(Alignment.CENTRE);
wcf_title.setBorder(Border.ALL,BorderLineStyle.THIN);
}
catch(WriteException e){
}

ws = wbbook.createSheet(StringConverter.EnToChinese(title),sheetid+1);
ws.setColumnView(0,20);
ws.setColumnView(1,20);
ws.setColumnView(2,20);
ws.setColumnView(3,20);
try{
/**
* 写标题
*/
jxl.write.Label labelTitle = new jxl.write.Label(0,0,StringConverter.EnToChinese(title),wcf_title);
ws.mergeCells(0,0,3,0);
ws.addCell(labelTitle);
/**
* 写入船型内容
*/

SqlServerPool pool = new SqlServerPool();
int i=0,j=1,work=1;
String strsql = "select a.*,b.refvalue from shipref a left join refcontent b on b.refid=a.id "+
"where a.shipid="+shipid+" order by a.reftype desc";

ResultSet rs = pool.executeQuery(strsql);
while(rs.next()){

if(rs.getString("reftype").equals("文本")){
jxl.write.Label typeLabel = new jxl.write.Label(0,j++,rs.getString("refname"),wcf);
ws.addCell(typeLabel);
jxl.write.Label valueLabel = new jxl.write.Label(1,j-1,rs.getString("refvalue"),wcf);
ws.mergeCells(1,j,3,j);
ws.addCell(valueLabel);
}
else{
if(i%2 == 1){
jxl.write.Label typeLabel = new jxl.write.Label(0,j,rs.getString("refname"),wcf);
ws.addCell(typeLabel);
jxl.write.Label valueLabel = new jxl.write.Label(1,j,rs.getString("refvalue"),wcf);
ws.addCell(valueLabel);
}
else{
jxl.write.Label typeLabel = new jxl.write.Label(2,j++,rs.getString("refname"),wcf);
ws.addCell(typeLabel);
jxl.write.Label valueLabel = new jxl.write.Label(3,j-1,rs.getString("refvalue"),wcf);
ws.addCell(valueLabel);
}
work = j;
}
i++;
}

if(work%2 == 1){
jxl.write.Label additional1 = new jxl.write.Label(2,work,"",wcf);
ws.addCell(additional1);
jxl.write.Label additional2 = new jxl.write.Label(3,work,"",wcf);
ws.addCell(additional2);
}

wbbook.write();
wbbook.close();
os.flush();
os.close();
}
catch(Exception ex){
}
}
}[/size]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值