2

我正在使用 Apache POI-HSSF 处理 Excel 文件。

我的电子表格中有一个看起来像“115”的单元格。我验证它被格式化为“文本”(格式单元格 - >文本)。

但是,当我将其读取为 row.getCell(0).toString()

我得到这个字符串:“115.0”

这是不正确的。我应该得到“115”,因为它被明确格式化为文本。我怎样才能得到想要的结果?单元格可以是任何东西,数字或字符,我希望与单元格中的字符串相同。谢谢

4

2 回答 2

2

格式化为文本并不意味着存储为文本,它们是不同的。Excel 已将您的单元格存储为数字,当您向 POI 询问单元格时,您会得到一个数字单元格。

如果您询问您返回的单元格是什么类型,您会发现它的类型是 CELL_TYPE_NUMERIC 而不是 CELL_TYPE_STRING

您可能想要做的是使用DataFormatter 类按照 Excel 格式化您的单元格。然后它看起来就像你期望的那样。(以及格式化为货币、百分比等的单元格)

于 2011-06-04T06:05:24.083 回答
2

您应该调用 HSSFCell.getCellType() 方法来确定其类型。这是一种处理字符串或数字类型单元格的方法。(您可以轻松添加其他类型。)用于数字的格式将是有效格式,但不一定与电子表格的格式匹配。(这将在下面介绍。)

public static String getCellStringValue(final HSSFCell cell) {
    int cellType = cell.getCellType();
    String value;
    if (cellType == HSSFCell.CELL_TYPE_NUMERIC) {
        // Locale is optional here
        DataFormatter dataFormatter = new DataFormatter(Locale.US);
        value = dataFormatter.formatCellValue(cell);
    } else {
        // HSSFCell.CELL_TYPE_STRING
        value = cell.getStringCellValue();
    } // more cell types are possible. Add whatever you need.
    return value;
}

该代码不一定会像 Excel 中显示的那样格式化数字。如果您需要格式与电子表格格式完全匹配,您可以从单元格本身获取格式化程序。为此,您可以使用 DataFormatter 实例创建一个 Format 实例:

public static String getCellStringValue(final HSSFCell cell) {
    int cellType = cell.getCellType();
    String value;
    if (cellType == HSSFCell.CELL_TYPE_NUMERIC) {
        // Locale is optional here
        DataFormatter dataFormatter = new DataFormatter(Locale.US);
        Format format = dataFormatter.createFormat(cell);
        value = format.format(cell.getNumericCellValue());
    } else {
        // HSSFCell.CELL_TYPE_STRING
        value = cell.getStringCellValue();
    } // more cell types are possible. Add whatever you need.
    return value;
}
于 2015-04-16T02:17:33.463 回答