POI导出Excel模板工具类(使用jxls)

本文介绍如何利用jXLS库实现基于模板的Excel批量数据导出功能。通过示例展示了如何设置依赖、创建工具类进行数据填充及转换,并在业务层和服务层中调用相关方法完成导出操作。

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

引入jar:
<dependency>
    <groupId>net.sf.jxls</groupId> 
    <artifactId>jxls-core</artifactId> 
    <version>1.0.6</version> 
</dependency>






工具类:
import java.io.IOException;
import java.io.OutputStream;
import java.util.HashMap;
import java.util.List;
import java.util.Map;


import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.springframework.core.io.ClassPathResource;


import net.sf.jxls.transformer.XLSTransformer;


public class SheetUtils {


public static void exportById(OutputStream os,Object obj,String mark){
HSSFWorkbook wb = null;
try {
// 创建工作簿;
wb = new HSSFWorkbook(new ClassPathResource("template/export_emp.xls").getInputStream());
// 数据模型
Map<String,Object> model = new HashMap<String,Object>();
model.put(mark, obj);
XLSTransformer xlsTrans = new XLSTransformer();
xlsTrans.transformWorkbook(wb, model);
wb.write(os);
}catch(Exception e){
e.printStackTrace();
}finally {
if(null != wb){
try {
wb.close();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
}
public static void exportList(OutputStream os,@SuppressWarnings("rawtypes") List list,String mark,String modelPath){
HSSFWorkbook wb = null;
try {
// 创建工作簿;
wb = new HSSFWorkbook(new ClassPathResource(modelPath).getInputStream());
// 数据模型
Map<String,Object> model = new HashMap<String,Object>();
model.put(mark, list);
XLSTransformer xlsTrans = new XLSTransformer();
xlsTrans.transformWorkbook(wb, model);
wb.write(os);
}catch(Exception e){
e.printStackTrace();
}finally {
if(null != wb){
try {
wb.close();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
}
}


业务层调用:
@Override
public void export(OutputStream os,Emp emp1) throws Exception {
// 查询所有的员工;
List<Emp> emplist = empDao.getList(emp1, null, null);

for (Emp e : emplist) {
if(e.getGender()==0){
e.setSex("男");
}else{
e.setSex("女");
}
}
SheetUtils.exportList(os, emplist, "emplist","template/export_emp.xls");
 //这是未抽取为工具类时的代码
/*HSSFWorkbook wb = null;
try {
// 创建工作簿;
wb = new HSSFWorkbook(new ClassPathResource("template/export_emp.xls").getInputStream());

// 数据模型
Map<String,Object> model = new HashMap<String,Object>();
model.put("emplist", emplist);

XLSTransformer xlsTrans = new XLSTransformer();
xlsTrans.transformWorkbook(wb, model);
wb.write(os);
} finally {
if(null != wb){
wb.close();
}
}*/
}


控制层:
public void export() throws UnsupportedEncodingException{
HttpServletResponse res = ServletActionContext.getResponse();
String filename = new String("员工表.xls".getBytes(),"iso-8859-1");
try {
// 告诉浏览器,有个名称为XXX附件,下载文件, ISO-8859-1转码,否则下载下来的文件名为乱码
res.setHeader("Content-Disposition", "attachment;filename=" + filename);
empBiz.export(res.getOutputStream(),getT1());
}  catch (Exception e) {
log.error("导出文件失败",e);
}
}


excel模板:



<jx:forEach items="${emplist}" var="emp" varStatus="status">
${emp.uuid} ${emp.username}${emp.name}${emp.sex}${emp.email}${emp.tele}${emp.address}${emp.birthday}${emp.dep.name}

</jx:forEach>



excel自定义时间格式:yyyy/mm/dd hh:mm









评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值