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

相关文章

java中使用POI生成Excel并导出过程

《java中使用POI生成Excel并导出过程》:本文主要介绍java中使用POI生成Excel并导出过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录需求说明及实现方式需求完成通用代码版本1版本2结果展示type参数为atype参数为b总结注:本文章中代码均为

Python实现将MySQL中所有表的数据都导出为CSV文件并压缩

《Python实现将MySQL中所有表的数据都导出为CSV文件并压缩》这篇文章主要为大家详细介绍了如何使用Python将MySQL数据库中所有表的数据都导出为CSV文件到一个目录,并压缩为zip文件到... python将mysql数据库中所有表的数据都导出为CSV文件到一个目录,并压缩为zip文件到另一个

Python实现合并与拆分多个PDF文档中的指定页

《Python实现合并与拆分多个PDF文档中的指定页》这篇文章主要为大家详细介绍了如何使用Python实现将多个PDF文档中的指定页合并生成新的PDF以及拆分PDF,感兴趣的小伙伴可以参考一下... 安装所需要的库pip install PyPDF2 -i https://pypi.tuna.tsingh

Java导入、导出excel用法步骤保姆级教程(附封装好的工具类)

《Java导入、导出excel用法步骤保姆级教程(附封装好的工具类)》:本文主要介绍Java导入、导出excel的相关资料,讲解了使用Java和ApachePOI库将数据导出为Excel文件,包括... 目录前言一、引入Apache POI依赖二、用法&步骤2.1 创建Excel的元素2.3 样式和字体2.

使用EasyExcel实现简单的Excel表格解析操作

《使用EasyExcel实现简单的Excel表格解析操作》:本文主要介绍如何使用EasyExcel完成简单的表格解析操作,同时实现了大量数据情况下数据的分次批量入库,并记录每条数据入库的状态,感兴... 目录前言固定模板及表数据格式的解析实现Excel模板内容对应的实体类实现AnalysisEventLis

java导出pdf文件的详细实现方法

《java导出pdf文件的详细实现方法》:本文主要介绍java导出pdf文件的详细实现方法,包括制作模板、获取中文字体文件、实现后端服务以及前端发起请求并生成下载链接,需要的朋友可以参考下... 目录使用注意点包含内容1、制作pdf模板2、获取pdf导出中文需要的文件3、实现4、前端发起请求并生成下载链接使

使用Apache POI在Java中实现Excel单元格的合并

《使用ApachePOI在Java中实现Excel单元格的合并》在日常工作中,Excel是一个不可或缺的工具,尤其是在处理大量数据时,本文将介绍如何使用ApachePOI库在Java中实现Excel... 目录工具类介绍工具类代码调用示例依赖配置总结在日常工作中,Excel 是一个不可或缺的工http://

SpringBoot实现导出复杂对象到Excel文件

《SpringBoot实现导出复杂对象到Excel文件》这篇文章主要为大家详细介绍了如何使用Hutool和EasyExcel两种方式来实现在SpringBoot项目中导出复杂对象到Excel文件,需要... 在Spring Boot项目中导出复杂对象到Excel文件,可以利用Hutool或EasyExcel

使用Python创建一个能够筛选文件的PDF合并工具

《使用Python创建一个能够筛选文件的PDF合并工具》这篇文章主要为大家详细介绍了如何使用Python创建一个能够筛选文件的PDF合并工具,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下... 目录背景主要功能全部代码代码解析1. 初始化 wx.Frame 窗口2. 创建工具栏3. 创建布局和界面控件4

Python自动化办公之合并多个Excel

《Python自动化办公之合并多个Excel》在日常的办公自动化工作中,尤其是处理大量数据时,合并多个Excel表格是一个常见且繁琐的任务,下面小编就来为大家介绍一下如何使用Python轻松实现合... 目录为什么选择 python 自动化目标使用 Python 合并多个 Excel 文件安装所需库示例代码