java Poi操作Excel,插入行,保留行格式

文章介绍了在Java中使用ApachePOI库处理Excel时遇到的一个问题,即当尝试在最后一行插入新行时会失败。为解决此问题,提供了创建最后一行下一行的解决方案,并展示了如何在特定行后插入多行并复制样式。示例代码详细说明了插入和复制行样式的操作步骤。
摘要由CSDN通过智能技术生成

2023/03/20修改bug,startRow为最后一行时无法插入新行

如果复制最后一行,首先需要创建最后一行的下一行,否则无法插入

例1:

编辑

问:如果我想在李四下方插入一个空行该如何操作

我们应该在行标为3的下方插入1行

startRow = 3

row = 1


public static void main(String[] args) {
        ExcelWriter writer= ExcelUtil.getWriter(new File("C:\\Users\\Wsong\\Desktop\\template.xlsx"),"活动信息");
        int startRow= 3;
        introws=1;
        XSSFSheet sheet= (XSSFSheet)writer.getSheet();

        ExcelCopyUtils.InsertRow(writer, startRow, rows, sheet,false);
    }

结果

执行后的结果,我们可以看到样式与行标为3的行一致。

编辑

例2

问:在例1的结果基础上,我们想要在张三后插入3行,样式拷贝张三,如何操作

我们应该在行标为5的下方插入3行

startRow =5

row = 3


public static void main(String[] args) {
        ExcelWriter writer= ExcelUtil.getWriter(new File("C:\\Users\\Wsong\\Desktop\\template.xlsx"),"活动信息");
        int startRow= 5;
        introws=3;
        XSSFSheet sheet= (XSSFSheet)writer.getSheet();

        ExcelCopyUtils.InsertRow(writer, startRow, rows, sheet,false);
    }

结果

编辑

代码如下。

        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi</artifactId>
            <version>5.0.0</version>
        </dependency>
        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi-ooxml</artifactId>
            <version>5.0.0</version>
        </dependency>
        <dependency>
            <groupId>cn.hutool</groupId>
            <artifactId>hutool-all</artifactId>
            <version>5.0.5</version>
        </dependency>

package com.ws.excel;
 
 
import cn.hutool.poi.excel.ExcelUtil;
import cn.hutool.poi.excel.ExcelWriter;
import org.apache.poi.ss.usermodel.*;
import org.apache.poi.ss.util.CellRangeAddress;
import org.apache.poi.xssf.usermodel.XSSFSheet;
 
import java.io.File;
import java.util.List;
 
public class ExcelCopyUtils {
 
    public static void main(String[] args) {
        ExcelWriter writer = ExcelUtil.getWriter(new File("C:\\Users\\Wsong\\Desktop\\template.xlsx"),"活动信息");
        // startRow=5 行标为5的行后插入2行,样式拷贝第5行的样式
        int startRow= 5;
        int rows = 2;
        XSSFSheet sheet = (XSSFSheet)writer.getSheet();
 
        InsertRow(writer, startRow, rows, sheet,false);
    }
 
    /**
     *
     * @param writer ExcelWriter
     * @param startRow 插入行的行标,即在哪一行下插入
     * @param rows 插入多少行
     * @param sheet XSSFSheet
     * @param copyvalue 新行复制(startRow-1)行的样式,而且在拷贝行的时候可以指定是否需要拷贝值
     * @Author Wsong qzsoft
     */
    private static void InsertRow(ExcelWriter writer, int startRow, int rows, XSSFSheet sheet,Boolean copyvalue) {
        if(sheet.getRow(startRow+1)==null){
            // 如果复制最后一行,首先需要创建最后一行的下一行,否则无法插入,Bug 2023/03/20修复
            sheet.createRow(startRow+1);
        }
 
        //先获取原始的合并单元格address集合
        List<CellRangeAddress> originMerged = sheet.getMergedRegions();
 
        for (int i = sheet.getNumMergedRegions() - 1; i >= 0; i--) {
            CellRangeAddress region = sheet.getMergedRegion(i);
            //判断移动的行数后重新拆分
            if(region.getFirstRow()>startRow){
                sheet.removeMergedRegion(i);
            }
        }
 
        sheet.shiftRows(startRow,sheet.getLastRowNum(),rows,true,false);
        sheet.createRow(startRow);
 
        for(CellRangeAddress cellRangeAddress : originMerged) {
            //这里的8是插入行的index,表示这行之后才重新合并
            if(cellRangeAddress.getFirstRow() > startRow) {
                //你插入了几行就加几,我这里插入了一行,加1
                int firstRow = cellRangeAddress.getFirstRow() + rows;
                CellRangeAddress newCellRangeAddress = new CellRangeAddress(firstRow, (firstRow + (cellRangeAddress
                        .getLastRow() - cellRangeAddress.getFirstRow())), cellRangeAddress.getFirstColumn(),
                        cellRangeAddress.getLastColumn());
                sheet.addMergedRegion(newCellRangeAddress);
            }
        }
        writer.flush();
        CellCopyPolicy cellCopyPolicy = new CellCopyPolicy();
        cellCopyPolicy.setCopyCellValue(copyvalue);
        cellCopyPolicy.isCopyCellValue();
        for (int i = 0; i < rows; i++) {
            sheet.copyRows(startRow-1,startRow-1,startRow+i,cellCopyPolicy);
        }
        writer.close();
    }
}

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值