查找最后一列单元格值。如果单元格值为“无效”或“不适用”,则删除整行。
到目前为止我写的代码如下:
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.openxml4j.exceptions.InvalidFormatException;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.ss.usermodel.WorkbookFactory;
import org.apache.poi.ss.usermodel.Workbook;
public class Column
{
    public static void main(String[] args) throws InvalidFormatException, FileNotFoundException, IOException
    {
        try
        {
            Workbook wb = WorkbookFactory.create(new FileInputStream("C:/Users/Excel1.xlsx"));
            Sheet sheet = wb.getSheet("Retail-All");
            Workbook wb2 = new HSSFWorkbook();
            wb2 = wb;
            Row row;
            row = sheet.getRow(0);
            int getLastCell=row.getLastCellNum()-1;
            int lastIndex = sheet.getLastRowNum();
            for (int i=0; i<=lastIndex; i++)
            {
                row=sheet.getRow(i);
                if(row.getCell(getLastCell)!=null && (row.getCell(getLastCell).toString().equalsIgnoreCase("Not valid) || row.getCell(getLastCell).toString().equalsIgnoreCase("Not Applicable")))
                {
                    sheet.removeRow(row);
                    //sheet.shiftRows(i, lastIndex, -1);
                }
            }
            FileOutputStream fileOut = new FileOutputStream("C:/Users/shiftRows.xlsx");
            wb2.write(fileOut);
            fileOut.close();
        }
        catch (Exception e)
        {
            e.printStackTrace();
        }
    }
}
使用上面的代码,使用 row.setZeroHeight(true); 方法我可以隐藏行。
使用上面的代码,使用 sheet.removeRow(row); 方法我可以清空该特定行中的所有单元格。
我在网上找到了一些代码,但没有一个是永久删除行。我的要求是永久删除行。如何编码以满足我的要求?