我正在使用Selenium 2并设置了一个从数据驱动的excel文件中读取的LoginTest.java文件。我读了用户名和密码,并在登录页面上运行。它实际上运行良好。数据如下所示:
user1 pw1
user2 pw2
user3 pw3
user4 pw4
问题是:如果我修改excel文件并将参数数量改为这样:
user1 pw1
user2 pw2
并运行相同的脚本,ReadExcel
类文件返回错误消息:
“这种类型的细胞没有支持”。
我认为,正在发生的事情是第3行和第4行使用来包含其单元格中的数据(user3 pw3和user4 pw4),现在它们没有......所以有一些不同的东西关于我ExcelRead()
类没有忽略的以前使用过的单元格。我敢打赌,细胞现在是'无效',而以前它不是,反之亦然。以前持有数据的细胞与从未持有数据的细胞有所不同。
(我在互联网上找到了ExcelRead
并且正在使用它。我自己并没有从头开始创建它。除了这个'问题'之外,它似乎能正常读取xcel文件。)
感谢您的帮助。
public class ExcelRead {
public Object[][] main( String[] args) throws Exception{
File excel = new File(args[0]);
FileInputStream fis = new FileInputStream(excel);
HSSFWorkbook wb = new HSSFWorkbook(fis);
HSSFSheet ws = wb.getSheet(args[1]);
int rowNum = ws.getLastRowNum() + 1;
int colNum = ws.getRow(0).getLastCellNum();
String[][] data = new String[rowNum][colNum];
for (int i = 0 ; i < rowNum ; i++) {
HSSFRow row = ws.getRow(i);
for (int j = 0 ; j < colNum ; j++) {
HSSFCell cell = row.getCell(j);
String value = cellToString(cell);
data[i][j] = value ;
//System.out.println("the value is " + value);
}
}
return data;
}
public static String cellToString(HSSFCell cell) {
int type;
Object result;
type = cell.getCellType();
switch (type) {
case 0: // numeric value in Excel
result = cell.getNumericCellValue();
break;
case 1: // String Value in Excel
result = cell.getStringCellValue();
break;
default:
throw new RuntimeException("There is no support for this type of cell");
}
return result.toString();
}
答案 0 :(得分:1)
您下载的代码使用Java Apache POI库来读取excel文件。如果您浏览代码,您将看到cellToString()
方法不处理所有类型的单元格类型 - 它只查找数字和字符串单元格,并抛出您看到的异常。
从行中删除单元格值后,单元格值现在为空,您获得的单元格类型为CELL_TYPE_BLANK
。
您需要在switch
方法中扩展cellToString()
语句,以处理其他单元格类型,例如Cell.CELL_TYPE_BLANK
,Cell.CELL_TYPE_BOOLEAN
等。
请参阅Cell
界面上的Apache POI documentation,了解不同的细胞类型以及如何处理每种细胞类型。
public static String cellToString(HSSFCell cell) {
int type;
Object result;
type = cell.getCellType();
switch (type) {
case Cell.CELL_TYPE_NUMERIC: // numeric value in Excel
case Cell.CELL_TYPE_FORMULA: // precomputed value based on formula
result = cell.getNumericCellValue();
break;
case Cell.CELL_TYPE_STRING: // String Value in Excel
result = cell.getStringCellValue();
break;
case Cell.CELL_TYPE_BLANK:
result = "";
case Cell.CELL_TYPE_BOOLEAN: //boolean value
result: cell.getBooleanCellValue();
break;
case Cell.CELL_TYPE_ERROR:
default:
throw new RuntimeException("There is no support for this type of cell");
}
return result.toString();
}
答案 1 :(得分:0)
添加此内容。
case 3: break;
实际上,您需要检查空单元格类型(HSSFCell.CELL_TYPE_BLANK
)。
如果找到空单元格,您可以执行的操作是使用for
停止i=rowNum
循环。
有两种以上的细胞类型。 getCellType()
方法可以返回这些整数:
Cell.CELL_TYPE_NUMERIC, Cell.CELL_TYPE_STRING, Cell.CELL_TYPE_FORMULA, Cell.CELL_TYPE_BLANK, Cell.CELL_TYPE_BOOLEAN, Cell.CELL_TYPE_ERROR
<强>编辑:强>
根据对 Faiz 的观察,由于Object result
未初始化和未分配,因此会出现异常。相反,写case 3: return "";
时,如果找到空白单元格,它将返回一个空字符串。无论如何,你的算法不是最有效的。您应该搜索单元格,直到找到空单元格(如果工作表中没有空行),而不是搜索预定义的大区域。您应该能够使用ArrayList而不是Array,从而完全避免在密码检查过程中处理空字符串。
答案 2 :(得分:0)
在罐子下面,您需要使用Java从Excel读取数据。从this link
下载poi-4.1.0.jar
poi-ooxml-4.1.0.jar
xmlbeans-3.1.0.jar
ooxml-schemas-1.4.jar
commons-compress-1.18.jar
xlsx-streamer-2.1.0.jar
要读取Excel文件,请将其放置在下载位置或用户所需的位置。下面的程序使用以下Excel file。
Excel文件可能包含不同类型的CellType。在阅读列数据时,您需要提及 Apache POI 支持的大多数可用CellType。
我引用了以下案例BOOLEAN, STRING, NUMERIC, FORMULA, BLANK, _NONE, ERROR,
,如果没有案例支持,则以default
方法转到getCellValueAsString
。
package com.java.file.excel;
import java.io.FileInputStream;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.ss.usermodel.Workbook;
import com.monitorjbl.xlsx.StreamingReader;
/**
*
* @author udaykiran p
*
*/
public class ReadExcelFile {
public static void main(String[] args) {
try {
FileInputStream inputStream = new FileInputStream("C:\\Users\\udaykiranp\\Downloads\\Users.xlsx");// Read Excel file from this location
if (inputStream != null) {
Workbook wb = StreamingReader.builder().rowCacheSize(100) // number of rows to keep in memory (default to 10)
.bufferSize(4096) // buffer size is to use when reading InputStream to file (defaults to 1024)
.open(inputStream);
Sheet sheet = wb.getSheetAt(0);//reading first sheet. You can pass argument as well.
System.out.println("Excel Reading - Number Of Sheets: "+ wb.getNumberOfSheets() +", Active Sheet: "+ sheet.getSheetName());
Map<String, String> map = new HashMap<String, String>();
Iterator<Row> iterator = sheet.iterator();
int rowCount = 0;
while(iterator.hasNext()) {
Row row = iterator.next();
rowCount = row.getRowNum();
rowCount++;
int columnNum = 0;
String key = null, value = null;
for(Iterator<Cell> cellIterator = row.cellIterator(); cellIterator.hasNext();) {
Cell cell = cellIterator.next();
columnNum = cell.getColumnIndex();
String cellData = getCellValueAsString(cell);
System.out.println("RowNumber: "+ rowCount +", CellData: "+ cellData +", CellNumber: "+ columnNum);
//Reading data from Excel upto 6 rows only
// if (rowCount == 6) {
//rowCount == 1 Headers Section(User ID, User Name)
if (rowCount > 1) {
if (columnNum == 0) {
key = cellData;//User ID
}
if (columnNum == 1) {
value = cellData;//User Name
}
}
// }
}
if (key != null && value != null) {
map.put(key, value);
}
}
String userID = "1";
System.out.println("User ID: "+ userID +", User Name: "+ map.get("1"));
}
} catch (Exception e) {
e.printStackTrace();
}
}
private static String getCellValueAsString(Cell cell) {
String cellValue = null;
switch(cell.getCellType()) {
case BOOLEAN:
cellValue = String.valueOf(cell.getBooleanCellValue());
break;
case STRING:
cellValue = String.valueOf(cell.getRichStringCellValue().toString());
break;
case NUMERIC:
Double value = cell.getNumericCellValue();
if (value != null) {
String valueAsStr = value.toString();
int indexOf = valueAsStr.indexOf(".");
if (indexOf > 0) {
cellValue = valueAsStr.substring(0, indexOf);//decimal numbers truncated
} else {
cellValue = value.toString();
}
}
break;
case FORMULA:
//if the cell contains formula, this case will be executed.
cellValue = cell.getStringCellValue();
break;
case BLANK:
cellValue = "";
break;
case _NONE:
cellValue = "";
break;
case ERROR:
throw new RuntimeException("There is no support for this type of cell");
default:
cellValue = "";
}
return cellValue;
}
}
输出:
DEBUG [main] (StreamingWorkbookReader.java:89) - Created temp file
[C:\Users\UDAY~1\AppData\Local\Temp\tmp-6803178981463652112.xlsx]
Excel Reading - Number Of Sheets: 1, Active Sheet: Sheet1
RowNumber: 1, CellData: User ID, CellNumber: 0
RowNumber: 1, CellData: User Name, CellNumber: 1
RowNumber: 2, CellData: 1, CellNumber: 0
RowNumber: 2, CellData: Steve Jobs, CellNumber: 1
RowNumber: 3, CellData: 2, CellNumber: 0
RowNumber: 3, CellData: Bill Gates, CellNumber: 1
RowNumber: 4, CellData: 3, CellNumber: 0
RowNumber: 4, CellData: Sergey Brin, CellNumber: 1
RowNumber: 5, CellData: 4, CellNumber: 0
RowNumber: 5, CellData: Fritz Sennheiser, CellNumber: 1
RowNumber: 6, CellData: 5, CellNumber: 0
RowNumber: 6, CellData: Thomas Olsen, CellNumber: 1
User ID: 1, User Name: Steve Jobs