使用EasyExcel合并单元格
前言
在此,我想分享一些个人的经验和见解,希望能为同样追求进步的您提供一些启示和帮助。每一篇文章都是我深思熟虑的结果,欢迎您阅读、收藏并关注。在未来的日子里,我会继续分享更多的经验,与您共同探索更多未知的领域。请相信,每一次的分享都是我真挚的心意,期待与您共同成长,共创美好未来。
1、创建实体
import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.NoArgsConstructor;
/**
* @author jhb
* @desc 合并单元格 实体
* @date 2024-01-23
*/
@Data
@Builder
@AllArgsConstructor
@NoArgsConstructor
public class MergeRange {
/**
* 列索引
*/
private int columnIndex;
/**
* 开始行
*/
private int startRow;
/**
* 结束行
*/
private int endRow;
}
2、编写合并策略类
package net.jhb.utils;
import com.alibaba.excel.metadata.Head;
import com.alibaba.excel.write.merge.AbstractMergeStrategy;
import net.qihoo.mss.model.excel.MergeRange;
import org.apache.poi.ss.usermodel.*;
import org.apache.poi.ss.util.CellRangeAddress;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
/**
* @author jhb
* @desc 合并单元格策略类
* @date 2024-1-23
*/
public class MergeStrategy extends AbstractMergeStrategy {
/**
* 合并数据的信息
*/
private final Map<Integer, List<MergeRange>> mergeRangesMap;
public MergeStrategy(List<MergeRange> mergeRanges) {
this.mergeRangesMap = new HashMap<>();
for (MergeRange mergeRange : mergeRanges) {
int columnIndex &#