EasyExcel 文件导出 - 合并某些列值相同的行

2024-09-05 22:12

本文主要是介绍EasyExcel 文件导出 - 合并某些列值相同的行,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

    • EasyExcel 文件导出 - 合并某些列值相同的行
    • 最终效果
    • 实现思路
    • 创建单元格合并的策略类
    • 使用

EasyExcel 文件导出 - 合并某些列值相同的行

在数据处理与文件导出的过程中,我们常常会遇到各种特定的需求。今天,我们就来探讨一下使用 EasyExcel 进行文件导出时,如何合并某些列值相同的行,以实现更加高效和整洁的数据呈现。

最终效果

下面对2、3、4列进行单元格合并。
在这里插入图片描述

实现思路

判断当前行与上一行对应的值是否相等,若相等则进行合并操作。整个过程十分简洁明了。

创建单元格合并的策略类

注意:下面有使用lombok包,我的EasyExcel版本是4.0.2

public class RowSameValueMergeStrategy extends AbstractMergeStrategy {/*** 需要合并的列位置索引*/private int[] mergeColumnIndexArray;// 记录mergeColumnIndexArray中每一列的上一行的值和索引private Map<Integer, ValueAndIndex> lastValueMap;/*** 用来记录上一次的值和索引,用于判断是否需要合并*/@Data@AllArgsConstructorstatic class ValueAndIndex {private String value;private int index;}public RowSameValueMergeStrategy(int[] mergeColumnIndexArray) {this.mergeColumnIndexArray = mergeColumnIndexArray;int initialCapacity = (int) Math.ceil(mergeColumnIndexArray.length / 0.75);lastValueMap = new HashMap<>(initialCapacity);}@Overrideprotected void merge(Sheet sheet, Cell cell, Head head, Integer relativeRowIndex) {if (head == null) {return;}if (mergeColumnIndexArray == null) {return;}for (int i = 0; i < mergeColumnIndexArray.length; i++) {int mergeIndex = mergeColumnIndexArray[i];if (head.getColumnIndex() == mergeIndex) {String value = cell.getStringCellValue();int rowIndex = cell.getRowIndex();if (lastValueMap.get(mergeIndex) == null) {lastValueMap.put(mergeIndex, new ValueAndIndex(value, rowIndex));}ValueAndIndex valueAndIndex = lastValueMap.get(mergeIndex);Integer lastRowIndex = valueAndIndex.getIndex();String lastValue = valueAndIndex.getValue();// 合并值相同的相邻单元格,当前单元格合并上一个单元格if (Objects.equals(value, lastValue) && lastRowIndex != rowIndex) {sheet.addMergedRegionUnsafe(new CellRangeAddress(lastRowIndex, // 起始行rowIndex,     // 结束行mergeIndex,   // 起始列mergeIndex   // 结束列));}lastValueMap.put(mergeIndex, new ValueAndIndex(value, rowIndex));}}}}

使用

使用registerWriteHandler把上面的合并单元格的策略类注册即可。

         int[] mergeColumnIndexArray = {2, 3, 4}; // 要合并的列excelWriter = EasyExcel.write(outputStream, clazz).registerWriteHandler(new RowSameValueMergeStrategy(mergeColumnIndexArray)).build();

这篇关于EasyExcel 文件导出 - 合并某些列值相同的行的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1140207

相关文章

Python中合并列表(list)的六种方法小结

《Python中合并列表(list)的六种方法小结》本文主要介绍了Python中合并列表(list)的六种方法小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋... 目录一、直接用 + 合并列表二、用 extend() js方法三、用 zip() 函数交叉合并四、用

Mac备忘录怎么导出/备份和云同步? Mac备忘录使用技巧

《Mac备忘录怎么导出/备份和云同步?Mac备忘录使用技巧》备忘录作为iOS里简单而又不可或缺的一个系统应用,上手容易,可以满足我们日常生活中各种记录的需求,今天我们就来看看Mac备忘录的导出、... 「备忘录」是 MAC 上的一款常用应用,它可以帮助我们捕捉灵感、记录待办事项或保存重要信息。为了便于在不同

利用Python实现Excel文件智能合并工具

《利用Python实现Excel文件智能合并工具》有时候,我们需要将多个Excel文件按照特定顺序合并成一个文件,这样可以更方便地进行后续的数据处理和分析,下面我们看看如何使用Python实现Exce... 目录运行结果为什么需要这个工具技术实现工具的核心功能代码解析使用示例工具优化与扩展有时候,我们需要将

MySQL Workbench工具导出导入数据库方式

《MySQLWorkbench工具导出导入数据库方式》:本文主要介绍MySQLWorkbench工具导出导入数据库方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝... 目录mysql Workbench工具导出导入数据库第一步 www.chinasem.cn数据库导出第二步

Java如何根据word模板导出数据

《Java如何根据word模板导出数据》这篇文章主要为大家详细介绍了Java如何实现根据word模板导出数据,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... pom.XML文件导入依赖 <dependency> <groupId>cn.afterturn</groupId>

Python实现获取带合并单元格的表格数据

《Python实现获取带合并单元格的表格数据》由于在日常运维中经常出现一些合并单元格的表格,如果要获取数据比较麻烦,所以本文我们就来聊聊如何使用Python实现获取带合并单元格的表格数据吧... 由于在日常运维中经常出现一些合并单元格的表格,如果要获取数据比较麻烦,现将将封装成类,并通过调用list_exc

C#实现高性能Excel百万数据导出优化实战指南

《C#实现高性能Excel百万数据导出优化实战指南》在日常工作中,Excel数据导出是一个常见的需求,然而,当数据量较大时,性能和内存问题往往会成为限制导出效率的瓶颈,下面我们看看C#如何结合EPPl... 目录一、技术方案核心对比二、各方案选型建议三、性能对比数据四、核心代码实现1. MiniExcel

POI从入门到实战轻松完成EasyExcel使用及Excel导入导出功能

《POI从入门到实战轻松完成EasyExcel使用及Excel导入导出功能》ApachePOI是一个流行的Java库,用于处理MicrosoftOffice格式文件,提供丰富API来创建、读取和修改O... 目录前言:Apache POIEasyPoiEasyExcel一、EasyExcel1.1、核心特性

Python将博客内容html导出为Markdown格式

《Python将博客内容html导出为Markdown格式》Python将博客内容html导出为Markdown格式,通过博客url地址抓取文章,分析并提取出文章标题和内容,将内容构建成html,再转... 目录一、为什么要搞?二、准备如何搞?三、说搞咱就搞!抓取文章提取内容构建html转存markdown

vue使用docxtemplater导出word

《vue使用docxtemplater导出word》docxtemplater是一种邮件合并工具,以编程方式使用并处理条件、循环,并且可以扩展以插入任何内容,下面我们来看看如何使用docxtempl... 目录docxtemplatervue使用docxtemplater导出word安装常用语法 封装导出方