4

我有一个 3000 行的 excel 文件。我删除了 2000(使用 ms excel 应用程序),但是当我从代码中调用 sheet.getLastRowNum() 时,它给了我 3000(而不是 1000)。我怎样才能删除空白行?

我尝试了这里的代码,但它不起作用....

4

4 回答 4

8

有两种方法:

1.)无代码:复制你的excel内容并粘贴到一个新的excel中,以后根据需要重命名。

2.)使用代码(我没有找到任何函数,所以我创建了自己的函数):

您需要检查每个单元格中是否存在任何类型的空白/空字符串/空类型的东西。在处理之前(我希望您正在处理行明智,我也在使用org.apache.poi.xssf.usermodel.XSSFRow),进行if检查,并在if(condition)中检查此方法的返回类型,如果确实,这意味着 row(XSSFRow) 具有某些值,否则将迭代器移动到下一行

public boolean containsValue(XSSFRow row, int fcell, int lcell) 
{
    boolean flag = false;
    for (int i = fcell; i < lcell; i++) {
    if (StringUtils.isEmpty(String.valueOf(row.getCell(i))) == true || 
        StringUtils.isWhitespace(String.valueOf(row.getCell(i))) == true || 
        StringUtils.isBlank(String.valueOf(row.getCell(i))) == true || 
        String.valueOf(row.getCell(i)).length() == 0 || 
        row.getCell(i) == null) {} 
    else {
                flag = true;
        }
    }
        return flag;
}

所以最后你的处理方法看起来像

.
.
.
int fcell = row.getFirstCellNum();// first cell number of excel
int lcell = row.getLastCellNum(); //last cell number of excel
while (rows.hasNext()) {
row = (XSSFRow) rows.next();//increment the row iterator
if(containsValue(row, fcell, lcell) == true){

.
.
..//processing
.
.
}

}

希望这会有所帮助。:)

于 2013-07-30T11:18:20.617 回答
3

我还没有找到任何关于如何轻松获得“真实”行数的解决方案,但我找到了删除此类行的解决方案,这可能对解决类似问题的人有用。见下文。

我搜索了一下,找到了这个解决方案

它所做的只是从底部删除那些可能正是您想要的空行。

于 2013-07-30T12:30:02.120 回答
0

根据我对删除行的理解,您必须选择所有单元格并按下删除按钮。如果我是对的,那么您以错误的方式删除了行。通过这种方式,单元格变为空白而不被删除,因此行实际上包含具有空白值的单元格,这就是为什么要包含在行数中。

正确的方法是从第一个单元格左侧选择行号出现的行。单击行号将选择完整的行。在 shift 键的帮助下选择所有需要的行。现在右键单击,然后选择删除。

这可能对您有帮助。

于 2013-07-30T19:12:08.770 回答
-1
  1. 通过 poi api 删除行/列
  2. 将 xls 传输到 csv
  3. 将 csv 传输到 xls 希望这会对您有所帮助
于 2017-05-03T06:25:57.863 回答