easypoi报lastRow < firstRow || lastCol < firstCol问题描述

问题解析

1、合并单元格的开始行号大于结束行号,或者开始列号大于结束列号,导致合并失败,或者是模型上没有使用 @Excel()设置行号

解决办法

1、合并单元格的开始行号大于结束行号,或者开始列号大于结束列号,再进行导出数据的时候,线进行判断 。if(开始行号 > 结束行号 || 开始列号 > 结束列号){ return;}  

2、如果模型上没有设置行号,加入@Excel()行号就OK了

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Java中使用EasyExcel合并单元格后边界消失的问题,可以使用以下代码来重新设置单元格的边框: ```java // 获取合并后的单元格范围 CellRangeAddress range = new CellRangeAddress(firstRow, lastRow, firstCol, lastCol); // 设置单元格样式 CellStyle style = workbook.createCellStyle(); style.setBorderTop(BorderStyle.THIN); style.setBorderBottom(BorderStyle.THIN); style.setBorderLeft(BorderStyle.THIN); style.setBorderRight(BorderStyle.THIN); // 获取所有合并后的单元格 List<CellRangeAddress> mergedRegions = sheet.getMergedRegions(); for (CellRangeAddress mergedRegion : mergedRegions) { // 判断单元格是否与合并后的单元格有重叠 if (range.intersects(mergedRegion)) { // 获取重叠部分的单元格 int firstRow = Math.max(range.getFirstRow(), mergedRegion.getFirstRow()); int lastRow = Math.min(range.getLastRow(), mergedRegion.getLastRow()); int firstCol = Math.max(range.getFirstColumn(), mergedRegion.getFirstColumn()); int lastCol = Math.min(range.getLastColumn(), mergedRegion.getLastColumn()); // 重新设置单元格样式 for (int i = firstRow; i <= lastRow; i++) { for (int j = firstCol; j <= lastCol; j++) { Cell cell = sheet.getRow(i).getCell(j); cell.setCellStyle(style); } } } } ``` 其中,`firstRow`、`lastRow`、`firstCol`、`lastCol`分别表示合并后的单元格的起始行、结束行、起始列、结束列。`workbook`表示Excel工作簿,`sheet`表示工作簿中的工作表。 这段代码的作用是,遍历所有合并后的单元格,如果单元格与需要重新设置边框的单元格有重叠,则重新设置该单元格的边框样式。 希望这个代码能够帮助你解决问题
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值