我有一个代码,它使用Apache POI从excel表读取数据并将其存储为字符串数组。但我希望这些数据是double的数组,因为我必须将其用于其他目的。
我尝试使用Double.parseDouble将字符串更改为double。但是从excel文件中读取的数据就像@ 8bbab2f。
我也尝试将输出初始化为双数组,但会抛出错误。
那么如何使用Apache POI将数据作为双数组获取?
我的代码如下:
import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.ss.usermodel.Cell;
public class XLRead {
public static void main(String args[]) throws Exception {
Scanner in = new Scanner(System.in);
String wb_name;
wb_name = in.next();
File excel = new File("/Users/Documents/Sample_data/" + wb_name);
FileInputStream fis = new FileInputStream(excel);
HSSFWorkbook wb = new HSSFWorkbook(fis);
HSSFSheet sh = wb.getSheet("sample");
int rowNum = sh.getLastRowNum() + 1;
//System.out.println(rowNum);
int colNum = sh.getRow(0).getLastCellNum();
//System.out.println(colNum);
String[][] X0 = new String[rowNum][colNum];
// Here i tried to define X0 as double[][]. But it doesn't work.
for (int i = 3; i < 368; i++){
HSSFRow row = sh.getRow(i);
//System.out.println(row);
for (int j = 4; j <= 27; j++){
HSSFCell cell = row.getCell(j);
//System.out.println(cell);
String value = cellToString(cell);
X0[i][j] = value;
//System.out.println(value);
}
}
}
public static String cellToString(HSSFCell cell){
// i tried changing this function to public static double cellToDouble(HSSFCell cell)
int type;
Object result = null;
type = cell.getCellType();
if(cell!=null){
if (type == Cell.CELL_TYPE_FORMULA)
{
switch (cell.getCachedFormulaResultType()){
case Cell.CELL_TYPE_NUMERIC:
result = cell.getNumericCellValue();
break;
case Cell.CELL_TYPE_STRING:
result = cell.getStringCellValue();
break;
default:
throw new RuntimeException("Data type not applicable");
}
}
}
}
答案 0 :(得分:2)
您应该使用getNumericCellValue()
直接返回的double值,而不会以非常奇怪的方式将其转换为String并尝试将其转换回来,即
public static double getCellValue(HSSFCell cell){
switch (cell.getCachedFormulaResultType()){
case Cell.CELL_TYPE_NUMERIC:
return cell.getNumericCellValue();
break;
case Cell.CELL_TYPE_STRING:
return Double.parse(cell.getStringCellValue());
break;
default:
throw new RuntimeException("Data type not applicable");
}
}
然后将结果值放入double[]
。
顺便说一下,我还会检查为什么还有你想要读取的字符串格式的值。如果将所有值作为数值存储在Excel工作表中,则仅具有CELL_TYPE_NUMERIC-case就足够了。
答案 1 :(得分:1)
这应该有效:
final DataFormatter dataFormatter = new DataFormatter();
String cellValueAsString dataFormatter.formatCellValue(cell);
double cellValueAsDouble = Double.parseDouble(cellValueAsString);
我只用
进行了测试cell instanceof XSSFCell
虽然。根据区域设置,您可能还需要执行以下操作:
double cellValueAsDouble = Double.parseDouble(cellValueAsString.replace(',', '.'));
但最有可能是更好的解决方案。