我正在使用Apache POi HSSF库将Excel表导入并导出到我的应用程序(tableview) . 我想在Excel中使用特定ID从Excel中删除一行 . 有用 . 我的问题是,在我删除一行后,有一个空行,它删除的行多于所选行 . 大家可以帮忙吗?
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();
}
1 回答
这是我将如何做的一个例子:
一些评论:
您可以使用DataFormatter类来格式化单元格值(这样您就可以比较任何单元格值)
我 - 像你一样 - 比较细胞中的任何细胞;对我来说,典型的用例是搜索每行的第一个col来查找id . 如果您需要,请相应地调整代码 .
我最后做了换档行,这应该会更好 .