Как читать ячейки Excel, имеющие нулевые значения тоже в Java ...? - PullRequest
6 голосов
/ 28 июня 2010

Я использую Apache POI 3.6.У меня есть столбец, который является пустым .Я хотел бы иметь возможность прочитать его, а затем перейти к следующему столбцу.Даже если бы я смог решить проблему NullPointerException, я не смог бы добраться до следующей ячейки.

Вот мой фрагмент кода:

HSSFCell cell = row.getCell(c);
String value = null;

switch (cell.getCellType()) {

    case HSSFCell.CELL_TYPE_FORMULA:
        value = "FORMULA value=" + cell.getCellFormula();
        break;

    case HSSFCell.CELL_TYPE_NUMERIC:
        value = "NUMERIC value=" + cell.getNumericCellValue();
        break;

    case HSSFCell.CELL_TYPE_STRING:
        value = "STRING value=" + cell.getStringCellValue();
        break;

    case HSSFCell.CELL_TYPE_BLANK:
        value="";
        break;

    case HSSFCell.CELL_TYPE_ERROR:
        value="error";
        break;

    default:
        break;
}

System.out.println("CELL col=" + cell.getColumnIndex() + " VALUE=" + value);

Как мне решить мою проблему?

Ответы [ 4 ]

9 голосов
/ 29 июня 2010

Я наконец-то получил то, что хочу.Я благодарю mezmo за это.Я хочу поделиться точным фрагментом кода, который будет изменен.Просто замените строку, имеющую:

HSSFCell cell = row.getCell(c);

на

HSSFCell cell=row.getCell(c, org.apache.poi.ss.usermodel.Row.CREATE_NULL_AS_BLANK );
5 голосов
/ 28 июня 2010

Ну, вы можете проверить на null перед вашим оператором switch, или вы можете изменить, какой вызов row.getCell вы делаете.При проверке Javadoc для POI есть 2 формы, первая из которых используется, вторая имеет дополнительный параметр типа Row.MissingCellPolicy, где вы можете передать значение, которое автоматически преобразует пустые ячейки в пустые.

2 голосов
/ 28 июня 2010

Вам нужно проверить, если cell!=null, потому что, если ячейка не существует в строке, row.getCell(c) возвращает null

0 голосов
/ 13 июня 2012

Попробуйте это

List cellDataList = new ArrayList();
XSSFWorkbook workbook = new XSSFWorkbook(fileInputStream);

                        XSSFSheet sheet = workbook.getSheetAt(0);

                        Iterator rows = sheet.rowIterator();

                        int number=sheet.getLastRowNum();


                        int lineNumber = 0;

                        while (rows.hasNext())

                        {
                            XSSFRow row = ((XSSFRow) rows.next());
                            lineNumber++;
                            if(lineNumber==1){continue;}




                            Iterator cells = row.cellIterator();
                            List cellTempList = new ArrayList();    
                            int current = 0, next =1;
                            while(cells.hasNext())

                            {

                                XSSFCell cell = (XSSFCell) cells.next();


                                current = cell.getColumnIndex();


                                if(current<next){

                                }
                                else{

                                    int loop = current-next;

                                    for(int k=0;k<loop+1;k++){

                                        cellTempList.add(null);
                                        next = next + 1;
                                    }
                                }
                                switch (cell.getCellType()) {
                                            case Cell.CELL_TYPE_STRING:
                                                System.out.println(cell.getRichStringCellValue().getString());
                                                cellTempList.add(cell.getRichStringCellValue().getString());
                                                break;
                                            case Cell.CELL_TYPE_NUMERIC:                                                    
                                                    System.out.println(cell.getNumericCellValue());
                                                    cellTempList.add(String.valueOf(cell.getNumericCellValue()));                                                   
                                                break;
                                            case Cell.CELL_TYPE_BOOLEAN:
                                                System.out.println(cell.getBooleanCellValue());
                                                break;
                                            case Cell.CELL_TYPE_FORMULA:
                                                System.out.println(cell.getCellFormula());
                                                cellTempList.add(cell.getCellFormula());
                                                break;                                              

                                            default:
                                                System.out.println("Inside default");
                                }
                                next = next + 1;

                            }
                            cellDataList.add(cellTempList); 
                         }
...