如何使用Java Apache POI在Excel工作表中隐藏以下未使用的行?

java excel apache-poi rows

7931 观看

3回复

24343 作者的声誉

我正在使用数据库中的数据填充模板Excel工作表:

 for (Map<String, Object> resultRow : dbResults) {
        if ((currentRow = sheet.getRow(currentDataRow)) == null) {
            currentRow = sheet.createRow(currentDataRow);   // Creates a new row.
        }
        //currentRow.getRowStyle().setHidden(false);

        for (int i = 0; i < resultColumns; i++) {
            currentCell = currentRow.getCell(i, Row.CREATE_NULL_AS_BLANK);
            setCellValue(currentCell, resultRow.get(dbcolumnNames[i]));
        }
        currentDataRow += 1;
    }

// How to hide all empty/Un-used rows following currentDataRow ?

旨在实现:

  • 我想要隐藏填充行后面的未使用行吗?
  • 所有填充行必须可见。
  • 例如:如果填充了第1 100个数据行,则应隐藏101之后的行。

请帮忙 !!

作者: Yugal Jindle 的来源 发布者: 2011 年 8 月 3 日

回应 3


3

28830 作者的声誉

决定

POI会在您创建工作表时识别工作表中的逻辑行数。因此,当您用100行填充它时,它将创建100条记录。当您使用默认布局在Excel中打开XLS时,其余部分将显示 - 但这些不是POI记录。

你必须在你的最后一个数据记录之后创建一些虚拟行

for (int i=currentDataRow ;i<65000;i++)
                sheet.createRow(i);

创建单元格样式,并将其设置为隐藏

CellStyle hiddenstyle = workBook.createCellStyle();
hiddenstyle.setHidden(true);

为从最后一行到表格末尾的所有行设置此样式

while (rows.hasNext()){
                Row row1 = rows.next ();
                row1.setRowStyle(hiddenstyle);


            }
作者: JoseK 发布者: 2011 年 8 月 4 日

3

56 作者的声誉

row.setRowStye()row.getRowStye()存在于POI-3.8 BETA4。

作者: mahmudaq 发布者: 2011 年 8 月 31 日

5

51 作者的声誉

Row r = sheet.getRow(indexRow);
if ( r!=null ) {
    r.setZeroHeight(true);
}
作者: jezz 发布者: 2012 年 4 月 6 日
32x32