java - 替代已弃用的 getCellType

标签 java apache-poi

我正在使用 org.apache.poi 3.15 读取一个 excel 文件(文件扩展名为 xlsx)。

这是我的代码:

try (FileInputStream fileInputStream = new FileInputStream(file); XSSFWorkbook workbook = new XSSFWorkbook(file)) {
    XSSFSheet sheet = workbook.getSheetAt(0);
    Iterator<Row> rowIterator = sheet.iterator();
    while (rowIterator.hasNext()) {
        Row row = rowIterator.next();

        Iterator<Cell> cellIterator = row.cellIterator();
        while (cellIterator.hasNext()) {
            Cell cell = cellIterator.next();
            switch (cell.getCellType()) {
                case Cell.CELL_TYPE_NUMERIC:
                    System.out.print(cell.getNumericCellValue() + "(Integer)\t");
                    break;
                case Cell.CELL_TYPE_STRING:
                    System.out.print(cell.getStringCellValue() + "(String)\t");
                    break;
            }
        }
        System.out.println("");
    }
} catch (Exception e) {
    e.printStackTrace();
}

我收到警告说 cell.getCellType() 已弃用。谁能告诉我替代方案?

最佳答案

接受的答案显示了弃用的原因,但没有提及替代方案:

CellType    getCellTypeEnum()

CellType 是描述单元格类型的枚举。

计划在 POI 4.0 中将 getCellTypeEnum() 重命名为 getCellType()

关于java - 替代已弃用的 getCellType,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39993683/

相关文章:

java - 在 IntelliJ 中,如何在搜索(无处不在)结果中排除\target\*.html 文件?

java - 如何将 Excel 中的行插入到 mysql 数据库中?

java - 如何使用 SPQR 和 Spring 注册 ResolverInterceptors

java - Java 中用于密码模式的正则表达式

java - 指向一个hashSet java

java - 是否在for循环中使用break?

java - Apache POI 评估 SXSSF 工作簿中的公式

Java POI API : Convert from *. xlsx 到 *.xls

java - 将 List 实例写入 Excel 文件 - Apache POI

java - 如何在 Apache POI Word 中创建超链接?