您的位置:首页 > 其它

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

2017-11-07 23:18 423 查看
引入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
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: