easyExcel 获取多个sheet中复杂表头的数据

这篇具有很好参考价值的文章主要介绍了easyExcel 获取多个sheet中复杂表头的数据。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

easyExcel 获取多个sheet中复杂表头的数据

easyExcel 解释

EasyExcel是一个强大且易于使用的Java库,用于简化Excel文件的读写操作。它是阿里巴巴开源的一个基于POI实现的Excel处理工具,并提供了一组简单的API来处理Excel文件,包括读取、写入和转换。

EasyExcel的特点包括:

易于使用:EasyExcel提供了简单而直观的API,使得读取、写入和转换Excel文件变得容易。可以通过少量的代码实现复杂的Excel文件操作。

大数据量处理:EasyExcel对大数据量的处理进行了优化,支持高效读取和写入大型Excel文件,减少内存消耗和处理时间。

支持多种数据转换:EasyExcel支持将Excel文件与Java对象之间进行相互转换,可以方便地将Excel数据映射到Java对象,也可以将Java对象转换为Excel文件。

丰富的功能:EasyExcel提供了丰富的功能,包括支持读取和写入不同格式的Excel文件(例如xls和xlsx),支持读取和写入多个sheet,支持读取和写入复杂的Excel表头,支持数据校验等。

使用EasyExcel进行Excel操作通常包括以下步骤:

读取Excel文件:使用EasyExcel提供的API读取Excel文件,并将读取的数据映射到Java对象。

写入Excel文件:使用EasyExcel提供的API将Java对象数据写入Excel文件。

数据转换:使用EasyExcel提供的转换器功能,将Excel数据和Java对象之间进行相互转换。

总之,EasyExcel是一个功能强大且易于使用的Excel处理工具,它可以帮助开发人员更轻松地处理Excel文件,减少了代码量和开发时间。无论是处理大数据量还是进行数据转换,EasyExcel都是一个很好的选择。

实体

 @Data
public class HermalPowerRnterpriseVO {
	// index为excel中指定列(从0开始)
   @ExcelProperty(value = "名称", index = 0)
    private String name;
}

业务代码

    @Override
    public void importData(MultipartFile file) {
        //初始化实体
        Map<String, AbstractMap.SimpleEntry<Integer, Class<?>>> sheetMap = initializeSheetMap();
        Map<Class<?>, List<Object>> entityMap = initializeEntityMap(sheetMap);
        //声明并初始化inputStream
        try (InputStream inputStream = file.getInputStream()) {
            // 读取excel
            List<ReadSheet> readSheetList = EasyExcel.read(inputStream).build().excelExecutor().sheetList();

            for (ReadSheet readSheet : readSheetList) {
                //读取特定Excel表格
                try (InputStream sheetInputStream = file.getInputStream()) {
                    AbstractMap.SimpleEntry<Integer, Class<?>> sheetInfo = sheetMap.get(readSheet.getSheetName());
                    if (sheetInfo != null) {
                        readSheet(sheetInputStream, sheetInfo.getKey(), sheetInfo.getValue(), entityMap.get(sheetInfo.getValue()));
                    }
                } catch (Exception e) {
                    e.printStackTrace();
                }
            }

            // 输出读到的内容
            for (Map.Entry<Class<?>, List<Object>> entry : entityMap.entrySet()) {
                log.info(entry.getKey().getSimpleName() + ": " + JSON.toJSONString(entry.getValue()));
            }

        } catch (IOException e) {
            e.printStackTrace();
        }
    }

    /**
     * 初始化sheet内容
     * XXX 为sheet的名称,0,1,2,3为指定的sheet下表
     */
    private Map<String, AbstractMap.SimpleEntry<Integer, Class<?>>> initializeSheetMap() {
        Map<String, AbstractMap.SimpleEntry<Integer, Class<?>>> sheetMap = new HashMap<>(16);
        sheetMap.put("XXX", new AbstractMap.SimpleEntry<>(0, LoadVO.class));
        sheetMap.put("XXX", new AbstractMap.SimpleEntry<>(1, HermalPowerRnterpriseVO.class));
        sheetMap.put("XXX", new AbstractMap.SimpleEntry<>(2, HydropowerEnterpriseVO.class));
        sheetMap.put("XXX", new AbstractMap.SimpleEntry<>(3, CentralizedSceneryVO.class));
        sheetMap.put("XXX", new AbstractMap.SimpleEntry<>(4, NewEnergyStorageVO.class));
        sheetMap.put("XXX", new AbstractMap.SimpleEntry<>(5, PowerAggregatorVO.class));
        sheetMap.put("XXX", new AbstractMap.SimpleEntry<>(6, LoadAggregatorVO.class));
        sheetMap.put("XXX", new AbstractMap.SimpleEntry<>(7, AggregateBodyVO.class));
        return sheetMap;
    }

    /**
     * 初始化entity内容
     */
    private Map<Class<?>, List<Object>> initializeEntityMap(Map<String, AbstractMap.SimpleEntry<Integer, Class<?>>> sheetMap) {
        Map<Class<?>, List<Object>> entityMap = new HashMap<>(16);
        for (Class<?> clazz : sheetMap.values().stream().map(AbstractMap.SimpleEntry::getValue).distinct().toArray(Class<?>[]::new)) {
            entityMap.put(clazz, new ArrayList<>());
        }
        return entityMap;
    }

    /**
     * 获取sheet数据
     */
    private void readSheet(InputStream inputStream, Integer sheetNum, Class<?> clazz, List<?> dataList) {
        EasyExcel.read(inputStream, clazz, new EasyExcelVOListener(dataList))
				//sheetNum为获取第几个sheet的数据
                .sheet(sheetNum)
                // 跳过表头
                .headRowNumber(2)
                .doRead();
    }
    
@AllArgsConstructor
public class EasyExcelVOListener<T> extends AnalysisEventListener<T> {

    private List<T> dataList ;

    @Override
    public void invoke(T data, AnalysisContext context) {
        dataList.add(data);
    }

    @Override
    public void doAfterAllAnalysed(AnalysisContext context) {

    }
}

优化2.0

问题:版本1.0会生成临时文件(这是因为EasyExcel的底层,它使用了ZipFile来处理Excel文件,而未正确关闭ZipFile可能会导致资源泄漏),程序会走垃圾清除:Cleaning up unclosed ZipFile for archive
解决:使用 EasyExcel.read()方法的另一个重载,以关闭自动生成的临时文件。使用 ExcelReader 对象来替代
EasyExcel.read().build().excelExecutor().sheetList(),然后在 finally 块中调用 excelReader.finish() 来关闭和删除临时文件。

临时文件问题代码文章来源地址https://www.toymoban.com/news/detail-811664.html

 List<ReadSheet> readSheetList = EasyExcel.read(inputStream).build().excelExecutor().sheetList();
    @Override
    public void importData(MultipartFile file) {
        //初始化excel实体
        Map<String, AbstractMap.SimpleEntry<Integer, Class<?>>> sheetMap = initializeSheetMap();
        Map<Class<?>, List<Object>> entityMap = initializeEntityMap(sheetMap);
        ExcelReader excelReader = null;
        //声明并初始化inputStream
        try (InputStream inputStream = file.getInputStream()) {
            excelReader = EasyExcel.read(inputStream).build();
            // 读取excel
            List<ReadSheet> readSheetList = excelReader.excelExecutor().sheetList();

            for (ReadSheet readSheet : readSheetList) {
                //读取特定Excel表格
                try (InputStream sheetInputStream = file.getInputStream()) {
                    AbstractMap.SimpleEntry<Integer, Class<?>> sheetInfo = sheetMap.get(readSheet.getSheetName());
                    if (sheetInfo != null) {
                        readSheet(sheetInputStream, sheetInfo.getKey(), sheetInfo.getValue(), entityMap.get(sheetInfo.getValue()));
                    }
                } catch (Exception e) {
                    e.printStackTrace();
                }
            }

            // 输出读到的内容
            for (Map.Entry<Class<?>, List<Object>> entry : entityMap.entrySet()) {
                log.info(entry.getKey().getSimpleName() + ": " + JSON.toJSONString(entry.getValue()));
            }
        } catch (IOException e) {
            e.printStackTrace();
        }finally {
            if (excelReader != null) {
                excelReader.finish();
            }
        }
    }

到了这里,关于easyExcel 获取多个sheet中复杂表头的数据的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • EasyExcel复杂表头导出(一对多)升级版

            在之前写的 EasyExcel复杂表头导出(一对多)的博客的结尾,受限于当时的能力和精力,留下一些问题及展望。现在写下此博客,目的就是解决之前遗留的问题。         背景介绍,见上述链接指向的博客,这里主要通过 自定义拦截器 的形式来完美解决。 对于图

    2024年02月06日
    浏览(59)
  • 【Python】excel多个sheet数据合并实例

    因为,每天都会有的大量excel报表汇总处理任务,所以写了一个脚本来处理。 就是找出每一个excel中特定的sheet,把这些sheet的特定列读取出来合并到一个sheet中。 因为每一个sheet的数据都不太一样,所以稍微麻烦一点,下面使用openpyxl方式和pandas两种方式来处理。 使用openpyx

    2024年02月02日
    浏览(47)
  • poi带表头多sheet导出

    导出工具类 导出实体主表类 导出sheet1表 导出sheet2表 导出 导出结果

    2024年02月11日
    浏览(43)
  • Java利用POI导入Excel数据(多个sheet、模板)

    需求:根据excel模板导入数据            sheet1:1-6行为固定格式,且需要取值({xxx});7行开始为数据集合(list)            sheet2:都为固定格式,取值地方:{xxx}         1、数据格式(两个Sheet)   2、代码

    2024年02月16日
    浏览(49)
  • EasyExcel导入读取所有的sheet页

    读取一个sheet用EasyExcel.read() .sheet().doRead(); 读取所有的sheet用EasyExcel.read() .doReadAll(); 上代码: 依赖: 实体要与Excel文档一一对应,可以index,下标从0开始;也可以用value,内容和Excel列保持一致 下面这个是Excel实体,我这里用的value 下面这个是数据库实体,我尝试Excel实体和数

    2024年02月16日
    浏览(36)
  • EasyExcel读取多sheet excel异常

    使用Spring Boot集成EasyExcel进行导入excel多sheet,执行异常 file是MultipartFile,入参,主要处理流程如下 异常: com.alibaba.excel.exception.ExcelCommonException: Convert excel format exception.You can try specifying the ‘excelType’ yourself 按照描述,缺少excelType参数,补充后,代码大概如下: 异常: com.

    2024年02月16日
    浏览(37)
  • EasyExcel动态表头导出(支持多级表头)

    在很多业务场景中,都会应用到动态表头的导出,也会涉及到多级表头的导出,如下图所示 通过EasyExcel,我们可以快速实现这一需求,具体代码如下 maven依赖 DynamicHeader.java CustomTitleWriteHandler.java CellStyle.java DynamicExcelUtils.java

    2024年02月08日
    浏览(72)
  • EasyExcel导出工具类(支持模板导出多Sheet导出)

    最近写需求发现没有顺手excel导出工具类, 于是自己造了个小轮子, 链式一\\\".\\\"到底, 代码既注释 特点: 支持多sheet 支持从模板导出 支持分页拿数据, 避免数据量过大一次拿出导致内存溢出 数据类型支持业务实体类或Map, 无需easyExcel的注解, 低侵入   over

    2024年02月16日
    浏览(44)
  • java中用SXSSFWorkbook把多个list数据和单个实体dto导出到excel如何导出到多个sheet页详细实例?(亲测)

    以下是一个详细的示例,展示了如何使用SXSSFWorkbook将多个List数据和单个实体DTO导出到多个Sheet页: import org.apache.poi.xssf.streaming.SXSSFWorkbook; import org.apache.poi.xssf.streaming.SXSSFSheet; import org.apache.poi.xssf.streaming.SXSSFRow; import org.apache.poi.xssf.streaming.SXSSFCell; import java.io.FileOutputStream;

    2024年02月11日
    浏览(47)
  • easyexcel 实现表头批注

    场景;在业务逻辑中,导出的时候需要给客户提供下载的模版,上传的文件有些字段值需要验证,如果不按照验证的规则,后端解析的时候就会失败,所以在导出模版需要给客户一个提示,一种方法是下载的模版中加入示例数据,另外一种就是在表头添加上备注。 以下是表头

    2024年02月13日
    浏览(32)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包