解决excel读到时空白行rowHanler重复执行的问题。

This commit is contained in:
hellozrh
2023-01-16 15:06:25 +08:00
parent 9994083fe1
commit c660d79bf2
4 changed files with 88 additions and 2 deletions

View File

@@ -1,7 +1,9 @@
package cn.hutool.poi.excel.sax;
import cn.hutool.core.collection.CollUtil;
import cn.hutool.core.io.IoUtil;
import cn.hutool.core.lang.Assert;
import cn.hutool.core.util.ArrayUtil;
import cn.hutool.core.util.ObjectUtil;
import cn.hutool.core.util.StrUtil;
import cn.hutool.poi.excel.sax.handler.RowHandler;
@@ -344,8 +346,11 @@ public class Excel03SaxReader implements HSSFListener, ExcelSaxReader<Excel03Sax
* @param lastCell 行结束的标识Record
*/
private void processLastCell(LastCellOfRowDummyRecord lastCell) {
// 每行结束时, 调用handle() 方法
this.rowHandler.handle(curRid, lastCell.getRow(), this.rowCellList);
if(CollUtil.isNotBlank(this.rowCellList)) {
//整行内容全为空时表示该行是空白行不执行每行结束的handle.
// 每行结束时, 调用handle() 方法
this.rowHandler.handle(curRid, lastCell.getRow(), this.rowCellList);
}
// 清空行Cache
this.rowCellList = new ArrayList<>(this.rowCellList.size());
}

View File

@@ -1,11 +1,21 @@
package cn.hutool.poi.excel;
import cn.hutool.core.collection.CollUtil;
import cn.hutool.core.collection.CollectionUtil;
import cn.hutool.core.util.ArrayUtil;
import cn.hutool.core.util.ObjectUtil;
import cn.hutool.core.util.StrUtil;
import cn.hutool.poi.excel.cell.CellLocation;
import cn.hutool.poi.excel.sax.handler.RowHandler;
import org.junit.Assert;
import org.junit.Test;
import java.io.FileInputStream;
import java.io.InputStream;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;
import java.util.concurrent.atomic.AtomicInteger;
public class ExcelUtilTest {
@@ -61,4 +71,23 @@ public class ExcelUtilTest {
reader.close();
Assert.assertEquals(1L, list.get(1).get("鞋码"));
}
@Test
public void readBySaxTest() {
String path = "readBySax.xls";
AtomicInteger assertRowNum = new AtomicInteger(0);
try{
ExcelUtil.readBySax(path, 0, new RowHandler() {
@Override
public void handle(int sheetIndex, long rowIndex, List<Object> rowCells) {
System.out.println(StrUtil.format("sheetIndex={};rowIndex={},rowCells={}",sheetIndex,rowIndex,rowCells));
assertRowNum.addAndGet(1);
}
});
}catch (Exception ex){
ex.printStackTrace();
}
Assert.assertEquals(3, assertRowNum.intValue());
}
}