Apache POI - 删除并上移 Cell

Apache POI - Delete and move up Cell

我正在使用 Apache POi HSSF 库将 Excel table 导入和导出到我的应用程序(table视图)。我想从 Java 中删除 Excel 中具有特定 ID 的行。有用。我的问题是,在我删除一行后,有一个空行并且它删除的行多于选定的行。大家可以帮忙吗?

FileInputStream inp = new FileInputStream(
            "...............";

    HSSFWorkbook wb = (HSSFWorkbook) WorkbookFactory.create(inp);
    HSSFSheet sheet = wb.getSheetAt(0);

    String selectedid = auftragTabelle.getSelectionModel().getSelectedItem().getId();

    int rowIndex = 0;
    int lastRowNum = sheet.getLastRowNum();

    for (Row row : sheet) {
        for (Cell cell : row) {
            if (cell.getCellType() == Cell.CELL_TYPE_STRING) {
                if (cell.getRichStringCellValue().getString().trim().equals(selectedid)) {
                    rowIndex = cell.getRowIndex();
                }
            }
        }
    }

    if (rowIndex >= 0 && rowIndex < lastRowNum) {
        sheet.shiftRows(rowIndex, lastRowNum, -1);
    }

    if (rowIndex <= lastRowNum) {
        HSSFRow removingRow = sheet.getRow(rowIndex);

        if (removingRow != null) {
            sheet.removeRow(removingRow);
        }
    }

    OutputStream out = new FileOutputStream(
            "............";

    wb.write(out);
    out.close();

}

这是我将如何做的一个例子:

public static void main(String[] args) throws InvalidFormatException, IOException {
    FileInputStream inp = new FileInputStream(FILENAME);

    HSSFWorkbook wb = (HSSFWorkbook) WorkbookFactory.create(inp);
    HSSFSheet sheet = wb.getSheetAt(0);

    String selectedid = "3";

    int rowIndex = getRowIndexOfId(sheet, selectedid);

    removeRow(sheet, rowIndex);

    OutputStream out = new FileOutputStream(FILENAME);

    wb.write(out);
    out.close();
}
private static int getRowIndexOfId(HSSFSheet sheet, String selectedid) {
    DataFormatter formatter = new DataFormatter();
    for (Row row : sheet) {
        for (Cell cell : row) {
            if (formatter.formatCellValue(cell).trim().equals(selectedid)) {
                return row.getRowNum();
            }
        }
    }
    return -1;
}
private static void removeRow(HSSFSheet sheet, int rowIndex) {
    if (rowIndex >= 0) {
        sheet.removeRow(sheet.getRow(rowIndex));
        if(rowIndex < sheet.getLastRowNum()) {
            sheet.shiftRows(rowIndex + 1, sheet.getLastRowNum(), -1);
        }
    }
}

几点评论:

  1. 您可以使用 class DataFormatter 来格式化单元格值(这样您就可以比较任何单元格值)

  2. 我——和你一样——比较一个单元格中的任意一个单元格;对我来说,典型的用例是搜索每行的第一列以找到 id。因此,如果您需要,请相应地调整代码。

  3. 我最后做了换行,应该效果更好