赞
踩
目录
官方文档:
使用注解在字段上进行标识
使用最简单的方法二即可
- /**
- * 最简单的写
- * <p>
- * 1. 创建excel对应的实体对象 参照{@link DemoData}
- * <p>
- * 2. 直接写即可
- */
- @Test
- public void simpleWrite() {
- // 注意 simpleWrite在数据量不大的情况下可以使用(5000以内,具体也要看实际情况),数据量大参照 重复多次写入
-
- // 写法1 JDK8+
- // since: 3.0.0-beta1
- String fileName = TestFileUtil.getPath() + "simpleWrite" + System.currentTimeMillis() + ".xlsx";
- // 这里 需要指定写用哪个class去写,然后写到第一个sheet,名字为模板 然后文件流会自动关闭
- // 如果这里想使用03 则 传入excelType参数即可
- EasyExcel.write(fileName, DemoData.class)
- .sheet("模板")
- .doWrite(() -> {
- // 分页查询数据
- return data();
- });
-
- // 写法2
- fileName = TestFileUtil.getPath() + "simpleWrite" + System.currentTimeMillis() + ".xlsx";
- // 这里 需要指定写用哪个class去写,然后写到第一个sheet,名字为模板 然后文件流会自动关闭
- // 如果这里想使用03 则 传入excelType参数即可
- EasyExcel.write(fileName, DemoData.class).sheet("模板").doWrite(data());
-
- // 写法3
- fileName = TestFileUtil.getPath() + "simpleWrite" + System.currentTimeMillis() + ".xlsx";
- // 这里 需要指定写用哪个class去写
- try (ExcelWriter excelWriter = EasyExcel.write(fileName, DemoData.class).build()) {
- WriteSheet writeSheet = EasyExcel.writerSheet("模板").build();
- excelWriter.write(data(), writeSheet);
- }
- }

- @Getter
- @Setter
- @EqualsAndHashCode
- public class DemoData {
- private String string;
- private Date date;
- private Double doubleData;
- }
读的时候涉及到一个监听器对象,所有读的时候进行的后续操作一般都放在监听器中
自定义的监听器代码,
阿里巴巴要:因为监听器不受spring管理,所以你要想在监听器中操作数据库,必须按照人家要求使用构造方法传入
- // 有个很重要的点 DemoDataListener 不能被spring管理,要每次读取excel都要new,然后里面用到spring可以构造方法传进去
- //这个自定义监听器的功能是定义了一个100的缓冲区,没当list达到了100则写入数据库
- @Slf4j // 这个泛型填读取对象的实体,比如excel 表里对应的实体是user,那这个地方就填user
- public class DemoDataListener implements ReadListener<DemoData> {
-
- /**
- * 每隔5条存储数据库,实际使用中可以100条,然后清理list ,方便内存回收
- */
- private static final int BATCH_COUNT = 100;
- /**
- * 缓存的数据
- */
- private List<DemoData> cachedDataList = ListUtils.newArrayListWithExpectedSize(BATCH_COUNT);
- /**
- * 假设这个是一个DAO,当然有业务逻辑这个也可以是一个service。当然如果不用存储这个对象没用。
- */
- private DemoDAO demoDAO;
-
- public DemoDataListener() {
- // 这里是demo,所以随便new一个。实际使用如果到了spring,请使用下面的有参构造函数
- demoDAO = new DemoDAO();
- }
-
- /**
- * 如果使用了spring,请使用这个构造方法。每次创建Listener的时候需要把spring管理的类传进来
- *
- * @param demoDAO
- */
- public DemoDataListener(DemoDAO demoDAO) {
- this.demoDAO = demoDAO;
- }
-
- /**
- * 这个每一条数据解析都会来调用
- *
- * @param data one row value. Is is same as {@link AnalysisContext#readRowHolder()}
- * @param context
- */
- @Override
- public void invoke(DemoData data, AnalysisContext context) {
- log.info("解析到一条数据:{}", JSON.toJSONString(data));
- cachedDataList.add(data);
- // 达到BATCH_COUNT了,需要去存储一次数据库,防止数据几万条数据在内存,容易OOM
- if (cachedDataList.size() >= BATCH_COUNT) {
- saveData();
- // 存储完成清理 list
- cachedDataList = ListUtils.newArrayListWithExpectedSize(BATCH_COUNT);
- }
- }
-
- /**
- * 所有数据解析完成了 都会来调用,上面没达到100的,没有触发保存数据库
- 最后就执行这个方法,把遗留的存进去
- *
- * @param context
- */
- @Override
- public void doAfterAllAnalysed(AnalysisContext context) {
- // 这里也要保存数据,确保最后遗留的数据也存储到数据库
- saveData();
- log.info("所有数据解析完成!");
- }
-
- /**
- * 加上存储数据库
- */
- private void saveData() {
- log.info("{}条数据,开始存储数据库!", cachedDataList.size());
- demoDAO.save(cachedDataList);
- log.info("存储数据库成功!");
- }
- }

最简单的读
想省事不自定义监听器对象可以直接参考写法一
- /**
- * 最简单的读
- * <p>
- * 1. 创建excel对应的实体对象 参照{@link DemoData}
- * <p>
- * 2. 由于默认一行行的读取excel,所以需要创建excel一行一行的回调监听器,参照{@link DemoDataListener}
- * <p>
- * 3. 直接读即可
- */
- @Test
- public void simpleRead() {
- // 写法1:JDK8+ ,不用额外写一个DemoDataListener
- // since: 3.0.0-beta1
- String fileName = TestFileUtil.getPath() + "demo" + File.separator + "demo.xlsx";
- // 这里默认每次会读取100条数据 然后返回过来 直接调用使用数据就行
- // 具体需要返回多少行可以在`PageReadListener`的构造函数设置
- //如果使用spring,并且想保存到数据库,这个泛型填service 或者 dao,从而调用数据库
- EasyExcel.read(fileName, DemoData.class, new PageReadListener<DemoData>(dataList -> {
- for (DemoData demoData : dataList) {
- log.info("读取到一条数据{}", JSON.toJSONString(demoData));
- }
- })).sheet().doRead();
-
- // 写法2:
- // 匿名内部类 不用额外写一个DemoDataListener
- fileName = TestFileUtil.getPath() + "demo" + File.separator + "demo.xlsx";
- // 这里 需要指定读用哪个class去读,然后读取第一个sheet 文件流会自动关闭
- EasyExcel.read(fileName, DemoData.class, new ReadListener<DemoData>() {
- /**
- * 单次缓存的数据量
- */
- public static final int BATCH_COUNT = 100;
- /**
- *临时存储
- */
- private List<DemoData> cachedDataList = ListUtils.newArrayListWithExpectedSize(BATCH_COUNT);
-
- @Override
- public void invoke(DemoData data, AnalysisContext context) {
- cachedDataList.add(data);
- if (cachedDataList.size() >= BATCH_COUNT) {
- saveData();
- // 存储完成清理 list
- cachedDataList = ListUtils.newArrayListWithExpectedSize(BATCH_COUNT);
- }
- }
-
- @Override
- public void doAfterAllAnalysed(AnalysisContext context) {
- saveData();
- }
-
- /**
- * 加上存储数据库
- */
- private void saveData() {
- log.info("{}条数据,开始存储数据库!", cachedDataList.size());
- log.info("存储数据库成功!");
- }
- }).sheet().doRead();
-
- // 有个很重要的点 DemoDataListener 不能被spring管理,要每次读取excel都要new,然后里面用到spring可以构造方法传进去
- // 写法3:
- fileName = TestFileUtil.getPath() + "demo" + File.separator + "demo.xlsx";
- // 这里 需要指定读用哪个class去读,然后读取第一个sheet 文件流会自动关闭
- EasyExcel.read(fileName, DemoData.class, new DemoDataListener()).sheet().doRead();
-
- // 写法4
- fileName = TestFileUtil.getPath() + "demo" + File.separator + "demo.xlsx";
- // 一个文件一个reader
- try (ExcelReader excelReader = EasyExcel.read(fileName, DemoData.class, new DemoDataListener()).build()) {
- // 构建一个sheet 这里可以指定名字或者no
- ReadSheet readSheet = EasyExcel.readSheet(0).build();
- // 读取一个sheet
- excelReader.read(readSheet);
- }
- }

Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。