easyExcel实战:(四)easyExcel读深入解读

一、提升读速度加入缓冲功能,获取一个文件后,加入到BufferInputStream,写也有对应的BufferOutputStream:

InputStream inputStream = new FileInputStream("D:\\test1.xlsx");
BufferInputStream bis = new BufferInputStream( inputStream );

二、建议采用07版本的Excel完成读写,性能更好。

三、读1000行以内的数据(其实easyExcel小于1000行的它直接用了poi来读写):

非java模型写法:

List data = EasyExcelFactory.read(bis, new Sheet(1, 0));

java模型写法:

List 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 datas = new ArrayList();
    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 getDatas() {
        return datas;
    }
    public void setDatas(List datas) {
        this.datas = datas;
    }
}

 

 

 

 

你可能感兴趣的:(工具类)