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模板:
![](https://img-blog.csdn.net/20171107232154979?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvamNtY29t/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center)
<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
<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
相关文章推荐
- 使用POI插件,提取导出excel的工具类
- 使用工具类 使用poi导入导出excel报表
- 使用poi通过excel模板导出excel数据
- Excel基于POI利用反射返回Bean导入、Excel基于POI导出、Excel利用jxls导出、Excel模板导出
- JAVA使用poi进行EXCEL模板导入导出,XSSFCell数据类型
- Java工具类--使用模板方法导出Excel
- Java 工具类 - 使用POI以及反射实现导出Excel的功能
- poi 导出Excel 使用工具类
- java中使用poi导出数据到EXCEL模板中。
- jxls 使用模板文件导出生成excel
- java操作Excel之POI(5)利用POI实现使用模板批量导出数据
- 使用poi通过excel模板导出excel数据
- 使用POI动态更新导出的EXCEL模板中的列
- 使用jxls按模板导出excel数据
- poi读取excel模板,填充内容并导出,支持导出2007支持公式自动计算
- JAVA使用POI根据模版导出EXCEL
- 使用POI导出excel
- 利用POI将数据导出到EXCEL模板
- Java使用POI导出到Excel。