Use Apache POI in Java to read integers from numeric units
•
Java
I have an application that uses Apache POI to read the XLS table When a cell has a value, I use row getCell(i). Getnumericvalue() reads it But it returns a floating point number Just as the cell value is 1, it returns 1.0 Can I convert it to int? Any help will be greatly appreciated I tried integer ParseInt (value) – but it throws a numberformat exception Thank you for any help Here is the pseudo code:
FileInputStream file = new FileInputStream(new File("C:\\test.xls")); HSSFWorkbook workbook = new HSSFWorkbook(file); HSSFSheet 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: String value= String.valueOf(cell.getNumericCellValue()); int intVal = Integer.parseInt(value)-->>throws Exception
Solution
You can use a simple procedure to read the int value as a string Apache poi
First, use the following method to calculate the number of rows in the worksheet
private int getRowCount(Sheet currentSheet) { int rowCount = 0; Iterator<Row> rowIterator = currentSheet.iterator(); while(rowIterator.hasNext()) { Row row = rowIterator.next(); if(row == null || row.getCell(0) == null || row.getCell(0).getStringCellValue().trim().equals("") || row.getCell(0).toString().trim().equals("") || row.getCell(0).getCellType()==Cell.CELL_TYPE_BLANK){ break; } else rowCount=rowCount + 1; } return rowCount; }
Then use the following code in your method
Workbook workbook = WorkbookFactory.create(new File("c:/test.xls"); Sheet marksSheet = (Sheet) workbook.getSheet("Sheet1"); int zoneLastCount = 0; if(marksSheet !=null ) { zoneLastCount = getRowCount(marksSheet); } int zone = zoneLastCount-1; int column=1 for(int i = 0; i < zone; i++) { Row currentrow = marksSheet.getRow(i); double year = Double.parseDouble(currentrow.getCell(columnno).toString()); int year1 = (int)year; String str = String.valueOf(year1); }
The content of this article comes from the network collection of netizens. It is used as a learning reference. The copyright belongs to the original author.
THE END
二维码