Чтение данных ячейки excel в виде строки, которая имеет числовое значение / значение int, используя POI api [duplicate]

NullPointerException s - исключения, возникающие при попытке использовать ссылку, которая указывает на отсутствие местоположения в памяти (null), как если бы она ссылалась на объект. Вызов метода по нулевой ссылке или попытка получить доступ к полю нулевой ссылки вызовет функцию NullPointerException. Они наиболее распространены, но другие способы перечислены на странице NullPointerException javadoc.

Вероятно, самый быстрый пример кода, который я мог бы придумать для иллюстрации NullPointerException, be:

public class Example {

    public static void main(String[] args) {
        Object obj = null;
        obj.hashCode();
    }

}

В первой строке внутри main я явно устанавливаю ссылку Object obj равной null. Это означает, что у меня есть ссылка, но она не указывает на какой-либо объект. После этого я пытаюсь обработать ссылку так, как если бы она указывала на объект, вызывая метод на нем. Это приводит к NullPointerException, потому что нет кода для выполнения в местоположении, на которое указывает ссылка.

(Это техничность, но я думаю, что она упоминает: ссылка, которая указывает на null, равна 't то же, что и указатель C, указывающий на недопустимую ячейку памяти. Нулевой указатель буквально не указывает на в любом месте , который отличается от указаний на местоположение, которое оказывается недопустимым.)

10
задан Bnrdo 16 October 2013 в 11:45
поделиться

3 ответа

Excel хранит некоторые ячейки как строки, но чаще всего числа с особыми правилами форматирования, применяемыми к ним. Что вам нужно сделать, это заставить эти правила форматирования работать против числовых ячеек, чтобы создавать строки, которые выглядят так, как в Excel.

К счастью, Apache POI имеет класс, чтобы сделать именно это - DataFormatter

Все, что вам нужно сделать, это что-то вроде:

 Workbook wb = WorkbookFactory.create(new File("myfile.xls"));
 DataFormatter df = new DataFormatter();

 Sheet s = wb.getSheetAt(0);
 Row r1 = s.getRow(0);
 Cell cA1 = r1.getCell(0);

 String asItLooksInExcel = df.formatCellValue(cA1);

Не имеет значения, какой тип ячейки, DataFormatter будет отформатировать его, насколько это возможно для вас, используя правила, применяемые в Excel

18
ответ дан Gagravarr 19 August 2018 в 12:21
поделиться

Используйте CellType , вы можете проверить все

if (cellValue.getCellType() == Cell.CELL_TYPE_NUMERIC)

// cellValue является числовым

if (cellValue.getCellType() == Cell.CELL_TYPE_STRING)

// cellValue является Строка

date также указана как числовая, в то время проверить данную ячейку на дату или нет, используя dateUtil

if (DateUtil.isCellDateFormatted(cellData))

после того, как вы сможете конвертировать значение ячейки в дату

0
ответ дан newuser 19 August 2018 в 12:21
поделиться
  • 1
    Я уже сделал это, моя проблема в том, что исходный формат данных не восстанавливается. – Bnrdo 16 October 2013 в 12:04
  • 2
    Я попытался получить числовое значение как String by getStringCellValue (), я получил исключение. за это только я дал это. Можно ли получить строку как числовую. – newuser 16 October 2013 в 12:07
  • 3
  • 4
    Да, я задал тип ячейки ячейки в строке, но получаю неточный результат. Я уже сказал это в своем вопросе – Bnrdo 16 October 2013 в 12:25
  • 5
    Я также жду ответа – newuser 16 October 2013 в 12:33
1
ответ дан Patrice Rochemont 31 October 2018 в 00:31
поделиться
Другие вопросы по тегам:

Похожие вопросы: