EasyExcel自定义合并单元格-java

使用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 &#
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值