[英]Reading cell values from excel file using Apache POI
我正在使用Selenium 2,並設置了一個LoginTest.java文件,該文件從數據驅動的excel文件中讀取。 我輸入了用戶名和密碼,並在登錄頁面上運行它。 它實際上運行良好。 數據如下所示:
用戶1 pw1
用戶2 pw2
用戶3 pw3
用戶4
問題是這樣的:如果我修改了excel文件並將參數數量更改為以下形式:
用戶1 pw1
用戶2 pw2
並運行相同的腳本, ReadExcel
類文件將返回錯誤消息:
“不支持這種類型的單元”。
我認為正在發生的事情是,第3行和第4行過去曾在其單元格(user3 pw3和user4 pw4)中包含數據,而現在卻沒有...因此,那些以前使用的單元格與我的ExcelRead()
有所不同課堂上不容忽視。 我敢打賭,該單元格現在為“ null”,以前不是,反之亦然。 以前保存數據的單元格與從未保存過數據的單元格有所不同。
(我在網上找到了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();
}
您下載的代碼使用Java Apache POI庫讀取excel文件。 如果遍歷代碼,您將看到cellToString()
方法無法處理所有類型的單元格類型-它僅查找數字和字符串單元格,並引發否則會引發的異常。
從行中刪除單元格值后,單元格值現在為空,您將獲得CELL_TYPE_BLANK
單元格類型。
您需要在cellToString()
方法中擴展switch
語句,以處理其他單元格類型,例如Cell.CELL_TYPE_BLANK
, Cell.CELL_TYPE_BOOLEAN
等。
請參閱Cell
接口上的Apache POI文檔 ,以了解不同的cell類型以及如何處理每種cell。
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();
}
加上這個
case 3: break;
實際上,您需要檢查空的單元格類型( HSSFCell.CELL_TYPE_BLANK
)。
如果發現單元格為空,您也可以執行for
使用i=rowNum
停止for
循環。
單元格有兩種以上。 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
異常,因為Object result
未初始化和未分配。 而是寫case 3: return "";
找到空白單元格時,它將返回一個空字符串。 無論如何,您的算法並不是最有效的。 您應該搜索單元格,直到找到空單元格(如果工作表中沒有空行),而不是搜索預定義的大區域。 您應該能夠使用ArrayList而不是Array,從而完全避免在密碼檢查過程中處理空字符串。
在罐子下面,您需要使用Java從Excel讀取數據。 從此鏈接下載
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文件 。
Excel文件可能包含不同類型的CellType。 在閱讀列數據時,您需要提及Apache POI支持的大多數可用的CellType。
我引用以下情況BOOLEAN, STRING, NUMERIC, FORMULA, BLANK, _NONE, ERROR,
如果沒有任何情況支持,則在getCellValueAsString
方法getCellValueAsString
其設為default
。
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
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.