EasyExcel介绍
Java领域解析,生成Excel比较有名的框架有Apache poi,jxl等,但他们都存在一个严重的问题就是非常的耗内存,如果你的系统并发量不大的话可能还行,但是一旦并发上来后一定会OOM或者JVM频繁的full gc.
EasyExcel是阿里巴巴开源的一个excel处理框架,以使用简单,节省内存著称,EasyExcel能大大减少占用内存的主要原因是在解析Excel时没有将文件数据一次性全部加载到内存中,而是从磁盘上一行行读取数据,逐个解析。
EasyExcel采用一行一行的解析模式,并将一行的解析结果以观察者的模式通知处理(AnalysisEventListener)
1.引入依赖导入maven依赖,主要还需要poi的依赖,并且版本要对应上
com.alibaba
easyexcel
2.1.6
org.apache.poi
poi
3.17
org.apache.poi
poi-ooxml
3.17
2.编写实体对象类,和excel数据对应
@Data
public class ExcelData {
//设置excel表头名称
@ExcelProperty("学生编号")
private Integer sno;
@ExcelProperty("学生姓名")
private String sname;
}
3.实现Excel写操作
public class TestEasyExcel {
public static void main(String[] args) {
//创建list对象
List list = new ArrayList();
for(int i = 0;i<10;i++){
ExcelData data = new ExcelData();
data.setSno(i);
data.setSname("测试"+i);
list.add(data);
}
//实现Excel写操作
//设置写入文件夹地址和文件名称
String filename = "C:\\Users\\lenovo\\Desktop\\1.xls";
//调入EasyExcel里面的方法实现写入操作
//write两个参数为文件路径 和 实体类class .sheet设置Exel中sheet名称
EasyExcel.write(filename,ExcelData.class).sheet("学生列表").doWrite(list);
}
}
@Override
public void exportExcel(HttpServletResponse response, List baseInfoList, String filePath, String fileName) {
if(baseInfoList != null || baseInfoList.size()>0){
String path = filePath+"\\"+fileName+".xls"; //文件路径
//头的策略
WriteCellStyle headWriteStyle = new WriteCellStyle(); //单元格风格
WriteFont headFont = new WriteFont(); //设置字体
headFont.setFontHeightInPoints((short)10); //定义字体大小 ,标题默认加粗
headWriteStyle.setWriteFont(headFont); //把字体格式写入
headWriteStyle.setVerticalAlignment(VerticalAlignment.CENTER); //单元格居中
//设置内容格式
WriteCellStyle contentWriteStyle = new WriteCellStyle();
WriteFont contentFont = new WriteFont();
contentFont.setFontHeightInPoints((short)10);
contentWriteStyle.setWriteFont(contentFont); //把字体格式写入
contentWriteStyle.setHorizontalAlignment(HorizontalAlignment.CENTER); //水平居中
// 这个策略是 头是头的样式 内容是内容的样式 其他的策略可以自己实现
HorizontalCellStyleStrategy horizontalCellStyleStrategy = new HorizontalCellStyleStrategy(headWriteStyle,contentWriteStyle);
//建表
ExcelWriter excelWriter = EasyExcel.write(path,WellBaseInfoVo.class).build();
WriteSheet sheet = EasyExcel.writerSheet("现场井基础数据表").registerWriteHandler(horizontalCellStyleStrategy).build();
excelWriter.write(baseInfoList,sheet);
excelWriter.finish(); //关闭流
System.out.println("导出成功");
}
可以在实体中加入注解
@ExcelProperty 中的vlaue 表示列名,index 表示第几列
@ColumnWidth(15) 表示这一列的宽度
1.创建Excel实体类,标记对应列关系
@Data
public class ExcelData {
//设置excel表头名称 index = 0表示第一列
@ExcelProperty(value = "学生编号",index = 0)
private Integer sno;
@ExcelProperty(value = "学生姓名",index = 1)
private String sname;
}
2.创建监听对Excel进行读操作
public class ExcelListener extends AnalysisEventListener {
//一行一行的读取数据
@Override //这个注解表示重写父类方法,系统可以帮你检测方法的正确性
public void invoke(ExcelData excelData, AnalysisContext analysisContext) {
System.out.println("=="+excelData);
}
//读取表头方法
@Override
public void invokeHead(Map headMap, AnalysisContext context) {
System.out.println("表头:"+headMap);
}
//读完后的操作
@Override
public void doAfterAllAnalysed(AnalysisContext analysisContext) {
}
}
3.方法调用实现读操作
public class TestEasyExcel {
public static void main(String[] args) {
//实现Excel读操作
//设置读取Excel的路径
String filename = "C:\\Users\\lenovo\\Desktop\\1.xls";
EasyExcel.read(filename,ExcelData.class,new ExcelListener()).sheet().doRead();
}
}