Apache POI : How to format numeric cell values

前端 未结 4 576
青春惊慌失措
青春惊慌失措 2020-12-19 21:28

I am using Apache POI 3.9 for XLS/XLSX file processing.

In the XLS sheet, there is a column with numeric value like \"3000053406\".

When I read it with POI w

相关标签:
4条回答
  • 2020-12-19 22:13

    Creating a BigDecimal with the double value from the numeric cell and then using the

    BigDecimal.toPlainString()

    function to convert it to a plain string and then storing it back to the same cell after erasing the value solved the whole problem of exponential representation of numeric values.

    The below code solved the issue for me.

        Double dnum = cellContent.getNumericCellValue();
        BigDecimal bd = new BigDecimal(dnum);
        System.out.println(bd.toPlainString());
        cellContent.setBlank();
        cellContent.setCellValue(bd.toPlainString());
        System.out.println(cellContent.getStringCellValue());
    
    0 讨论(0)
  • 2020-12-19 22:20

    long varA = new Double(cellB1.getNumericCellValue()).longValue(); This will bring the exact value in variable varA.

    0 讨论(0)
  • 2020-12-19 22:30

    This one comes up very often....

    Picking one of my past answers to an almost identical question

    What you want to do is use the DataFormatter class. You pass this a cell, and it does its best to return you a string containing what Excel would show you for that cell. If you pass it a string cell, you'll get the string back. If you pass it a numeric cell with formatting rules applied, it will format the number based on them and give you the string back.

    For your case, I'd assume that the numeric cells have an integer formatting rule applied to them. If you ask DataFormatter to format those cells, it'll give you back a string with the integer string in it.

    0 讨论(0)
  • 2020-12-19 22:33

    Problem can be strictly Java-related, not POI related, too. Since your call returns a double,

    double val = cell.getNumericCellValue();

    You may want to get this

    DecimalFormat df = new DecimalFormat("#"); int fractionalDigits = 2; // say 2 df.setMaximumFractionDigits(fractionalDigits); double val = df.format(val);

    0 讨论(0)
提交回复
热议问题