hutool⾃定义excel_使⽤HutoolJava⼯具类库导出Excel超级简
在项⽬中,导出⽂件有时是必不可学少的需求;刚开始时,使⽤POI进⾏实现⽂件的导⼊导出功能;但是代码很多,对刚⼊⼿的⼩⽩来说,并不算友好;所以今天介绍⼀个Java⼯具类库————Hutool;
HuTool官⽹
Hutool简介
Hutool是⼀个⼩⽽全的Java⼯具类库,通过静态⽅法封装,降低相关API的学习成本,提⾼⼯作效率,使Java拥有函数式语⾔般的优雅,让Java语⾔也可以“甜甜的”。
Hutool中的⼯具⽅法来⾃于每个⽤户的精雕细琢,它涵盖了Java开发底层代码中的⽅⽅⾯⾯,它既是⼤型项⽬开发中解决⼩问题的利器,也是⼩型项⽬中的效率担当;
Hutool是项⽬中“util”包友好的替代,它节省了开发⼈员对项⽬中公⽤类和公⽤⼯具⽅法的封装时间,使开发专注于业务,同时可以最⼤限度的避免封装不完善带来的bug。
使⽤
⾸先在l中加⼊GAV
cn.hutool
hutool-all
5.0.7
org.apache.poi
poi-ooxml
4.1.1
org.apache.poi
poi-ooxml-schemas
3.17
然后在控制层使⽤就⾏
@RequestMapping("/export")
@ResponseBody
public void export(HttpServletResponse response){
List list = new ArrayList<>();
list.add(new User("zhangsan","1231",new Date()));
list.add(new User("zhangsan1","1232",new Date()));小白学java有前途吗
list.add(new User("zhangsan2","1233",new Date()));
list.add(new User("zhangsan3","1234",new Date()));
list.add(new User("zhangsan4","1235",new Date()));
list.add(new User("zhangsan5","1236", DateUtil.date(new Date())));
// 通过⼯具类创建writer,默认创建xls格式
ExcelWriter writer = Writer();
//⾃定义标题别名
writer.addHeaderAlias("name", "姓名");
writer.addHeaderAlias("age", "年龄");
writer.addHeaderAlias("birthDay", "⽣⽇");
// 合并单元格后的标题⾏,使⽤默认标题样式
<(2, "申请⼈员信息");
// ⼀次性写出内容,使⽤默认样式,强制输出标题
writer.write(list, true);
//out为OutputStream,需要写出到的⽬标流
//response为HttpServletResponse对象
response.setContentType("application/vnd.ms-excel;charset=utf-8");
//test.xls是弹出下载对话框的⽂件名,不能为中⽂,中⽂请⾃⾏编码
String name = Utf8String("申请学院");
response.setHeader("Content-Disposition","attachment;filename="+name+".xls"); ServletOutputStream out= null;
try {
out = OutputStream();
writer.flush(out, true);
} catch (IOException e) {
e.printStackTrace();
}finally {
// 关闭writer,释放内存
writer.close();
}
//此处记得关闭输出Servlet流
IoUtil.close(out);
}
来看看效果
导出效果
这样就可以完成Excel的导出了;怎么样?是不是很简单?

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。