使用Apache POI从Excel读取单元格

时间:2014-12-15 11:12:29

标签: java excel apache apache-poi

我是Apache POI的新手,所以我在使用它时遇到了一些麻烦。

我需要阅读一个Excel文件,但我不需要所有行,因为我使用此代码的最终目标是缩小文件(超过900行)以仅获取信息I&#39 ;稍后再使用。

所以我尝试使用以下代码:

public static void main(String[] args) {

    List<Planejado> planejados = new ArrayList<Planejado>();
    int i = 0;
    int linha = 5;

    try{
        FileInputStream fis = new FileInputStream("C:\\Users\\fs0234\\Desktop\\Projetos\\Realizado X Planejado\\Planej. Semanal por CC do Funcionário (20).xls");
        HSSFWorkbook wb = new HSSFWorkbook(fis);
        HSSFSheet sheet = wb.getSheetAt(0);

        int rowMax = sheet.getLastRowNum();

        while (i <= rowMax) { // interação do excel validando pela coluna I

            Row row = sheet.getRow(linha);
            Cell cell = row.getCell(9);



            if (cell.equals("")){   // Line 38  

                Planejado planejado = new Planejado();
                planejado.setCentroCusto("CC - " + i); // obter valor da celula j + contador
                planejado.setNomeRecurso("Recurso " + i); // obter valor da celula k + contador

                for(int j = 1; j < 53; j++) { //interação das colunas w até bw
                    planejado.getTimecard().put("Semana" + j, 40 + j);//obter o valor das horas
                }

                planejados.add(planejado);
            }
            linha++;
            i++;
        }

        for(Planejado planejado : planejados) { 
            //gravar no banco todos os objetos dentro da lista
            System.err.println(planejado.getCentroCusto() + " | " + planejado.getNomeRecurso() + " | " + planejado.getTimecard().get("Semana6"));
        }

    } catch (FileNotFoundException e) {
        e.printStackTrace();
    } catch (IOException e) {
        e.printStackTrace();
    }

我只需要第9列为空的行。

但是我得到了错误

  

&#34;线程中的异常&#34; main&#34;显示java.lang.NullPointerException     在main.PopulaPlanejado.main(PopulaPlanejado.java:38)&#34;

不知道我是否清楚我需要做什么,但我希望你们中的一些人可以帮助我。

2 个答案:

答案 0 :(得分:2)

而不是使用

if (cell.equals("")){
...
}

尝试使用此

if (cell == null || cell.getCellType() == Cell.CELL_TYPE_BLANK){
....
}

使用equals()进行对象比较时要小心,否则你最终会抛出NullPointerException。请记住,调用null结果对象上的任何方法都会抛出NPE。

您应该记住一些避免NullPointerException的最佳做法。

比较差

 if (state.equals("OK")) {
  ...
}

更好的比较

if ("OK".equals(state)) {
  ...
}

因此,在后一种情况下,您没有机会最终获得NPE。

希望它会对你有所帮助。 :)

答案 1 :(得分:0)

感谢您和我的其他朋友能够解决问题。

以下是没有错误的代码

List<Planejado> planejados = new ArrayList<Planejado>();
        int i = 0;
        int linha = 5;

        try {
            FileInputStream fis = new FileInputStream("C:\\Users\\fs0234\\Desktop\\Projetos\\Realizado X Planejado\\Planej. Semanal por CC do Funcionário (20).xls");
            HSSFWorkbook wb = new HSSFWorkbook(fis);
            HSSFSheet sheet = wb.getSheetAt(0);

            int rowMax = sheet.getLastRowNum();

            while (i <= rowMax) { // Loop até a última linha da planilha

                Row row = sheet.getRow(linha);

                if (row != null) { // Apenas linhas "não nulas"
                    Cell cell = row.getCell(8); // obter valor da celula I

                    if (cell == null || cell.getCellType() == Cell.CELL_TYPE_BLANK) { //Verifica se a coluna I é nula
                        Cell CC = row.getCell(6); // obter valor da celula G
                        Cell nome = row.getCell(10); // obter valor da celula K

                        Planejado planejado = new Planejado();
                        planejado.setCentroCusto("CC - " + CC);
                        planejado.setNomeRecurso("Recurso - " + nome);

                        for (int j = 1, weekCol = 22; j <= 53; j++, weekCol++) { // Loop para pegar todas as semanas

                            Cell week = row.getCell(weekCol); // Obter valor da coluna da semana

                            if (week != null) {
                                planejado.getTimecard().put("Semana" + j, week.getNumericCellValue());
                            } else {
                                planejado.getTimecard().put("Semana" + j, Double.valueOf(0));
                            }
                        }
                        planejados.add(planejado);
                    }
                }
                linha++;
                i++;
            }

            for (Planejado planejado : planejados) { 
                StringBuffer timecard = new StringBuffer();

                for (int k = 1; k < 53; k++) {
                    timecard.append("Semana " + k);
                    timecard.append(": ");
                    timecard.append(planejado.getTimecard().get("Semana" + k));
                    timecard.append(", ");
                }

                System.err.println(planejado.getCentroCusto() + " | " + planejado.getNomeRecurso() + " | " + timecard.toString());
            }

        } catch (FileNotFoundException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        }