java - 如何使用java在Selenium中已经打开的excel表上写
问题描述
我有 2 张 excel 表。目前我的要求是,我需要对 excel 列值执行一些操作,并将该值写入上述 Excel 表之一。下面我提到了我的代码,但它在第 3 行抛出错误。
File file=new File("D:\\Udaya files\\D-udaya files\\desktop_udaya files\\markting\\Gartner Dashboard\\Gartner Dashboard 28-12-2018\\AdminReportHTCoverPage.xlsx");
XSSFWorkbook wb=new XSSFWorkbook(file);
XSSFSheet sheet=wb.getSheetAt(1);
XSSFRow row=null;
int rowcount=sheet.getLastRowNum()+1;
File dashboard=new File("D:\\Udaya files\\D-udaya files\\desktop_udaya files\\markting\\Gartner Dashboard\\Gartner Dashboard 28-12-2018\\Weekly Dashboard_Garner users FY 18.xlsx");
XSSFWorkbook wb1=new XSSFWorkbook(dashboard);
XSSFSheet sheet1=wb.getSheet("December 28th");
XSSFRow row1=null;
int dashcount=sheet.getLastRowNum()+1;
int free=0;
int paid=0;
int paid_count=0;
for(int i=0;i<dashcount;i++)
{
String name=sheet1.getRow(i).getCell(1).getStringCellValue();
for(int j=0;j<rowcount;j++)
{
String firstname=sheet.getRow(i).getCell(1).getStringCellValue();
if(name.equals(firstname))
{
if(sheet.getRow(i).getCell(3).getStringCellValue()== "0" || sheet.getRow(i).getCell(3).getStringCellValue()== "")
{
free=free+1;
}
else
{
int value= (int) sheet.getRow(i).getCell(3).getNumericCellValue();
paid=paid+value;
paid_count=paid_count+1;
}
}
Row row3=sheet1.getRow(i);
row3.getCell(2).setCellValue(free);
row3.getCell(3).setCellValue(paid_count);
row3.getCell(4).setCellValue(paid);
}
}
getLastRowNum() 不适用于 sheet1 文件。它没有显示正确的数字。
解决方案
XSSFSheet.getLastRowNum()
是从零开始的。这就是为什么你认为如果你得到结果它不代表正确的数字row number - 1
。
如果行号5
在 Excel 工作表中,XSSFSheet.getLastRowNum()
将返回 4。
您还可以在下面的链接中找到很好的示例; http://poi.apache.org/components/spreadsheet/quick-guide.html
您在代码中遇到什么样的错误?
推荐阅读
- windows - LLVM 在 Windows 上构建:跳过了 Visual Studio cl.exe
- c# - Emgu GetAverage 图像的黑色颜色
- javascript - TypeError:Discord.Streaming 不是函数
- r - ggsave 不保存仅最后一个情节
- google-apps-script - 如何在谷歌应用程序脚本中包含 aws cognito 身份验证?
- python - 如何使用带有 .devcontainer.json 的 Docker 在 VSCode 中启动 jupyter lab
- c# - 如何在 C# 中使用 smtp 发送记录的电子邮件?
- html - 如何始终在页面底部获取页脚以获取不同的屏幕分辨率
- javascript - 通过在javascript中传递参数来更改嵌套数组对象
- java - 使用 apache camel 和 Kafka 时如何处理背压?