我正在尝试读取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());
}
答案 0 :(得分:2)
您的问题是您将该值作为double获取(Excel中的数字除少数边缘情况外,存储为浮点数)。从Java打印的浮点数没有前导零,使用科学格式等
假设你真正想要的是&#34;给我一个看起来就像Excel为这个单元显示的字符串&#34;,那么你不想打印原始双值。相反,您需要使用DataFormatter class,它提供了读取应用于单元格的Excel格式规则的方法,然后重新创建(尽可能)Java中的那些
您的代码应为:
DataFormatter fmt = new DataFormatter();
String numberAsInExcel = fmt.formatCellValue(cell);
这将根据Excel中应用的格式规则格式化数字,因此应按预期返回,前导零,非科学格式等