无法从数字单元格“Poi”中获取文本值

新手上路,请多包涵

我正在尝试在 Excel 中使用电子表格中的数据,但总是出现此错误,已经尝试将工作表格式化为文本和数字,但错误仍然存在。

我看到有人使用它解决了 cell.setCellType ( Cell.CELL_TYPE_STRING ) ; 但我不知道我在代码中的哪个位置放置了这段话。

 WebElement searchbox = driver.findElement(By.name("j_username"));
WebElement searchbox2 = driver.findElement(By.name("j_password"));

try {
    FileInputStream file = new FileInputStream(new File("C:\\paulo.xls"));
    HSSFWorkbook workbook = new HSSFWorkbook(file);
    HSSFSheet sheet = workbook.getSheetAt(0);

    for (int i=1; i <= sheet.getLastRowNum(); i++){
        String j_username = sheet.getRow(i).getCell(0).getStringCellValue();
        String j_password = sheet.getRow(i).getCell(0).getStringCellValue();

        searchbox.sendKeys(j_username);
        searchbox2.sendKeys(j_password);
        searchbox.submit();

        driver.manage().timeouts().implicitlyWait(10000, TimeUnit.MILLISECONDS);
    }

    workbook.close();
    file.close();
} catch (FileNotFoundException fnfe) {
    fnfe.printStackTrace();
} catch (IOException ioe) {
    ioe.printStackTrace();

原文由 Paulo Roberto 发布,翻译遵循 CC BY-SA 4.0 许可协议

阅读 1.2k
2 个回答

在这种情况下,格式化程序可以正常工作。

 import org.apache.poi.ss.usermodel.DataFormatter;

FileInputStream fis = new FileInputStream(workbookName);
Workbook workbook = WorkbookFactory.create(fis);
Sheet sheet = workbook.getSheet(sheetName);
DataFormatter formatter = new DataFormatter();
String val = formatter.formatCellValue(sheet.getRow(row).getCell(col));
list.add(val);   //Adding value to list

原文由 Manish 发布,翻译遵循 CC BY-SA 4.0 许可协议

    Cell cell = sheet.getRow(i).getCell(0);
    cell.setCellType ( Cell.CELL_TYPE_STRING );
    String j_username = cell.getStringCellValue();

更新

好的,正如评论中所说,尽管这有效,但它不是从 Excel 单元格中检索数据的正确方法。

根据 这里 的手册:

如果你想做的是为你的数字单元格获取一个字符串值,停止!这不是这样做的方法。相反,要获取数字或布尔值或日期单元格的字符串值,请改用 DataFormatter。

并根据 DataFormatter API

DataFormatter 包含用于格式化存储在 Cell 中的值的方法。 当您需要完全按照 Excel 中的显示显示数据时,这对于报告和 GUI 演示很有用。 支持的格式包括货币、SSN、百分比、小数、日期、电话号码、邮政编码等。

因此,显示数字单元格值的正确方法如下:

  DataFormatter formatter = new DataFormatter(); //creating formatter using the default locale
 Cell cell = sheet.getRow(i).getCell(0);
 String j_username = formatter.formatCellValue(cell); //Returns the formatted value of a cell as a String regardless of the cell type.

原文由 Anatoly 发布,翻译遵循 CC BY-SA 3.0 许可协议

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题