读取ms时保留的前导零优于apache POI

时间:2014-10-23 14:07:02

标签: java excel apache apache-poi

我正在尝试读取java中的.xlsx文件(使用Apache POI API),其单元格包含具有前导零的值。例如0590040100000124

但是在输出中我得到类似的东西

6247241.0< - > 5.90040100000124E14< - > 0.0 - < - > 5.90020100000125E14< - >  这是我的代码

public static void main(String[] args) throws FileNotFoundException, IOException  {
    // TODO Auto-generated method stub
    try{
    Workbook workbook = new XSSFWorkbook(new FileInputStream("C://dedup//dedup.xlsx"));
    String sheetName= workbook.getSheetName(0);
    System.out.println("Sheet Name:"+sheetName);
    double cellValues[] = new double[1000];

     for (int i = 0; i < workbook.getNumberOfSheets(); i++) {
            Sheet sheet = workbook.getSheetAt(i);


            int cellIndex=0;

            for (Row row : sheet) {
                for (Cell cell : row) {
                        //if(cell.toString()!=null){
                         cell.setCellType(Cell.CELL_TYPE_NUMERIC);
                        cellValues[cellIndex]=cell.getNumericCellValue();
                        cellIndex++;
                        //}
                    }
            }
            for(int k=0;k<cellValues.length;k++)
                System.out.print(cellValues[k]+" <-> "+"\t");
        }
    }catch(Exception e){
        System.out.println("JKB Exception Message:"+e.getMessage());
    }

1 个答案:

答案 0 :(得分:2)

您的问题是您将该值作为double获取(Excel中的数字除少数边缘情况外,存储为浮点数)。从Java打印的浮点数没有前导零,使用科学格式等

假设你真正想要的是&#34;给我一个看起来就像Excel为这个单元显示的字符串&#34;,那么你不想打印原始双值。相反,您需要使用DataFormatter class,它提供了读取应用于单元格的Excel格式规则的方法,然后重新创建(尽可能)Java中的那些

您的代码应为:

DataFormatter fmt = new DataFormatter();

String numberAsInExcel = fmt.formatCellValue(cell);

这将根据Excel中应用的格式规则格式化数字,因此应按预期返回,前导零,非科学格式等