Excel シートには約 5 レコードのデータがあり、1 つのレコードには 5 つの値があり、1 つのレコードには 4 つの値しかなく、1 つのレコードには 2 つの値しかありません。私のコードは空のセルを処理できません。私は得てdataprovider mismatch exception
います。誰かが私を助けることができますか?
Excel シート形式:
ここで、列のバージの下のデータはオプションであるため、いくつかのレコードでは空になります。
Excel シートを読み取る Java コード:
public static Object[][] getTableArray(String FilePath, String SheetName) throws Exception
{
String[][] tabArray = null;
try
{
FileInputStream ExcelFile = new FileInputStream(FilePath);
ExcelWBook = new XSSFWorkbook(ExcelFile);
ExcelWSheet = ExcelWBook.getSheet(SheetName);
int startRow = 1;
int startCol = 0;
int ci, cj;
row = ExcelWSheet.getRow(startRow);
int totalRows = ExcelWSheet.getLastRowNum();
int totalCols = row.getLastCellNum();
tabArray = new String[totalRows][totalCols];
ci = 0;
for (int i = startRow; i <= totalRows; i++, ci++)
{
cj = 0;
for (int j = startCol; j < totalCols; j++, cj++)
{
tabArray[ci][cj] = getCellData(i, j);
}
}
}catch (FileNotFoundException e) {
System.out.println("Could not find the Excel sheet");
e.printStackTrace();
}catch (IOException e) {
System.out.println("Could not read the Excel sheet");
e.printStackTrace();
}
return tabArray;
}
public static String getCellData(int RowNum, int ColNum) throws Exception {
try {
Cell = row.getCell(ColNum, org.apache.poi.ss.usermodel.Row.CREATE_NULL_AS_BLANK);
Cell = ExcelWSheet.getRow(RowNum).getCell(ColNum);
String CellData = Cell.getStringCellValue();
return CellData;
} catch (Exception e) {
System.out.println(e.getMessage());
throw e;
}
}
パラメータを受け入れる Java 関数:
@Test(dataProvider = "WelcomeMessage", priority = 2)
public void welcomemsg(String survey,String kw, String name, String verbiage, String audiofile, String barge) throws Exception {
try {
SurveyBuilderPage sp = PageFactory.initElements(MainConfig.getDriver(), SurveyBuilderPage.class);
sp.setWelcomeMessage(survey, kw, name, verbiage, audiofile, barge);
}
catch (Exception e) {
e.printStackTrace();
String stackTrace = new Object(){}.getClass().getEnclosingMethod().getName();
File screenshotFile = ((TakesScreenshot)MainConfig.getDriver()).getScreenshotAs(OutputType.FILE);
FileUtils.copyFile(screenshotFile, new File(userdir+"\\Screenshot"+stackTrace+".png"));
}
}
したがって、ここで次のようなエラーが発生します。
Dataprovider mismatch exception.
このwelcomemsg
関数は 6 つのパラメーターを想定していますが、6 番目のパラメーターはオプションです。だから私は得てdataprovider mismatch exception
います。ここでは、このオプションのパラメーターを処理する必要があります。
どんな助けでも大歓迎です。
前もって感謝します。