背景介绍
要频繁地往excel中插入行和删除行,所以行的sheet.getLastRowNum()值一直在变化。
在插入行的代码是
if(sheet.getPhysicalNumberOfRows()!=0){
int rowN=sheet.getLastRowNum()+1;
row=sheet.createRow(rowN);
}else{
row=sheet.createRow(sheet.getLastRowNum());
}
int i=0;
//具体赋值
row.createCell(i++).setCellValue(client.getUserNo());//用户号码
row.createCell(i++).setCellValue(client.getSimNo());//SIM号
所以要搞正确getLastRowNum()的值,统计出的行数,不能包括空行。在使用
sheet.shiftRows(i+1, sheet.getLastRowNum(), -1);
进行删除行时,使用getLastRowNum(),统计的行数,包括了一个空白的行。这个是因为shitRow是移动,
sheet.removeRow(row);
才是移除行,为了统计的行数不包括空白,并且不存在空白行,应该使用代码
public static void delteRow(){
try{
FileInputStream is = new FileInputStream("d://1.xls");
HSSFWorkbook workbook = new HSSFWorkbook(is);
HSSFSheet sheet = workbook.getSheetAt(0);
int ls=sheet.getLastRowNum();
sheet.shiftRows(1, ls, -1);
Row row=sheet.getRow(ls);
sheet.removeRow(row);
FileOutputStream os = new FileOutputStream("d://3.xls");
workbook.write(os);
is.close();
os.close();
} catch(Exception e) {
e.printStackTrace();
}
}
PS:其实很简单,但找方法的时候,一直没找对,曾相过设置shiftRow行为null,其实使用shiftRow,最后的行都没值,但不是null,不知道为什么还能使用getLastRowNum统计到该行。
也试过将row中cell设置为null,其实row不包括了cell.
这里 int ls=sheet.getLastRowNum(); 这段代码还要注意下。否则还是出现空白行被统计,为什么那,因为一个逻辑结构
本文详细介绍了在Excel中如何准确地插入和删除行而不留下空白行的方法。重点在于利用getLastRowNum()函数来获取正确的行数,并结合removeRow()方法来确保删除行后的Excel文件中不再存在空白行。
1万+

被折叠的 条评论
为什么被折叠?



