概述
一、提升读速度加入缓冲功能,获取一个文件后,加入到BufferInputStream,写也有对应的BufferOutputStream:
InputStream inputStream = new FileInputStream("D:\test1.xlsx");
BufferInputStream bis = new BufferInputStream( inputStream );
二、建议采用07版本的Excel完成读写,性能更好。
三、读1000行以内的数据(其实easyExcel小于1000行的它直接用了poi来读写):
非java模型写法:
List<Object> data = EasyExcelFactory.read(bis, new Sheet(1, 0));
java模型写法:
List<Object> data = EasyExcelFactory.read(bis, new Sheet(2, 1,JavaModelXXX.class));
注意:javaModelXXX.class extend BaseRowModel
四、超过1000行的大数据读Excel(easyExcel采用了一行行就进行解析):
非java模型写法:
ExcelListener excelListener = new ExcelListener();
EasyExcelFactory.readBySax(bis, new Sheet(1, 1), excelListener);
java模型写法:
ExcelListener excelListener = new ExcelListener();
EasyExcelFactory.readBySax(bis, new Sheet(2, 1,JavaModelXXX.class), excelListener)
注意这两个模式要去实现监听器的代码,例如:
/* 解析监听器,
* 每解析一行会回调invoke()方法。
* 整个excel解析结束会执行doAfterAllAnalysed()方法
*
* 下面只是我写的一个样例而已,可以根据自己的逻辑修改该类。
* @author jipengfei
* @date 2017/03/14
*/
public class ExcelListener extends AnalysisEventListener {
//自定义用于暂时存储data。
//可以通过实例获取该值
private List<Object> datas = new ArrayList<Object>();
public void invoke(Object object, AnalysisContext context) {
System.out.println("当前行:"+context.getCurrentRowNum());
System.out.println(object);
datas.add(object);//数据存储到list,供批量处理,或后续自己业务逻辑处理。
doSomething(object);//根据自己业务做处理
}
private void doSomething(Object object) {
//1、入库调用接口
}
public void doAfterAllAnalysed(AnalysisContext context) {
// datas.clear();//解析结束销毁不用的资源
}
public List<Object> getDatas() {
return datas;
}
public void setDatas(List<Object> datas) {
this.datas = datas;
}
}
最后
以上就是欢喜小土豆为你收集整理的easyExcel实战:(四)easyExcel读深入解读的全部内容,希望文章能够帮你解决easyExcel实战:(四)easyExcel读深入解读所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
发表评论 取消回复