java - XSSF。空指针异常

标签 java apache-poi xssf

private void cleaner(Integer columnsCount, Integer rowsCount, Object object){
    int firstColumn=0;
    int firstRow=0;
    XSSFSheet sheet = workBook.getSheetAt(0);
    for (int lineId=firstRow;lineId<rowsCount;lineId++)   {
        XSSFRow row = sheet.getRow(lineId);
        for (int columnId=firstColumn;columnId<columnsCount;columnId++){
            row.createCell(columnId).setCellValue(object.toString());  }
    }
}

我真的不明白这个逻辑。首先,我得到行,然后尝试写入数据。我当然知道,我的所有数据都不为空。 但编译器说:

Exception in thread "main" java.lang.NullPointerException
    at workhere.WriterXlsx.cleaner(WriterXlsx.java:75)
    at workhere.WriterXlsx.<init>(WriterXlsx.java:19)
    at workhere.Start.main(Start.java:28)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:606)
    at com.intellij.rt.execution.application.AppMain.main(AppMain.java:120)

WriterXlsx.java:75 : row.createCell(columnId).setCellValue(object.toString());

我用以下代码开始此方法:cleaner(30,30,"");

最佳答案

看看API

sheet.getRow(lineId);

如果行不存在则返回 null。您需要create在访问该行之前先添加一行,以防该行不存在(或跳过它)。

关于java - XSSF。空指针异常,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18586564/

相关文章:

java - Android:请求后一定时间检索网站的html

java - Java中如何读取对象

java - 在java中不使用excel来评估excel/其他语言表达式评估的库

java - 在java中获取文件的根路径

java - java中有 “createObject”吗?

java - 使用java将Ms word表格的单元格转换为图像

java - 使用多个外部 jar 文件编译和运行 java 程序

Excel 单元格格式 - XSSF 工作簿

spring - 使用 Apache poi 将 csv 转换为 xls/xlsx?

date - 如何使用 Apache POI XSSF 事件模型检查日期是否使用 1904 窗口