在實際應用中經常需要把Excel表格數據導入到數據庫,為此需求本人寫了一個讀取Excel數據的java類,現將代碼貼出來與大家一起分享。
該類提供兩個方法,一個方法用于讀取Excel表格的表頭,另一個方法用于讀取Excel表格的內容。
(注:本類需要POI組件的支持,POI是apache組織下的一個開源組件,)
代碼如下:
- package org.hnylj.poi.util;
- import java.io.FileInputStream;
- import java.io.FileNotFoundException;
- import java.io.IOException;
- import java.io.InputStream;
- import java.util.Date;
- import java.util.HashMap;
- import java.util.Map;
- import org.apache.poi.hssf.usermodel.HSSFCell;
- import org.apache.poi.hssf.usermodel.HSSFRow;
- import org.apache.poi.hssf.usermodel.HSSFSheet;
- import org.apache.poi.hssf.usermodel.HSSFWorkbook;
- import org.apache.poi.poifs.filesystem.POIFSFileSystem;
- /**
- *操作Excel表格的功能類
- *@author:hnylj
- *@version1.0
- */
- public class ExcelReader{
- private POIFSFileSystemfs;
- private HSSFWorkbookwb;
- private HSSFSheetsheet;
- private HSSFRowrow;
- /**
- *讀取Excel表格表頭的內容
- *@paramInputStream
- *@returnString表頭內容的數組
- *
- */
- public String[]readExcelTitle(InputStreamis){
- try {
- fs= new POIFSFileSystem(is);
- wb= new HSSFWorkbook(fs);
- } catch (IOExceptione){
- e.printStackTrace();
- }
- sheet=wb.getSheetAt( 0 );
- row=sheet.getRow( 0 );
- //標題總列數
- int colNum=row.getPhysicalNumberOfCells();
- String[]title= new String[colNum];
- for ( int i= 0 ;i<colNum;i++){
- title[i]=getStringCellValue(row.getCell(( short )i));
- }
- return title;
- }
- /**
- *讀取Excel數據內容
- *@paramInputStream
- *@returnMap包含單元格數據內容的Map對象
- */
- public Map<Integer,String>readExcelContent(InputStreamis){
- Map<Integer,String>content= new HashMap<Integer,String>();
- Stringstr= "" ;
- try {
- fs= new POIFSFileSystem(is);
- wb= new HSSFWorkbook(fs);
- } catch (IOExceptione){
- e.printStackTrace();
- }
- sheet=wb.getSheetAt( 0 );
- //得到總行數
- int rowNum=sheet.getLastRowNum();
- row=sheet.getRow( 0 );
- int colNum=row.getPhysicalNumberOfCells();
- //正文內容應該從第二行開始,第一行為表頭的標題
- for ( int i= 1 ;i<=rowNum;i++){
- row=sheet.getRow(i);
- int j= 0 ;
- while (j<colNum){
- //每個單元格的數據內容用"-"分割開,以后需要時用String類的replace()方法還原數據
- //也可以將每個單元格的數據設置到一個javabean的屬性中,此時需要新建一個javabean
- str+=getStringCellValue(row.getCell(( short )j)).trim()+ "-" ;
- j++;
- }
- content.put(i,str);
- str= "" ;
- }
- return content;
- }
- /**
- *獲取單元格數據內容為字符串類型的數據
- *@paramcellExcel單元格
- *@returnString單元格數據內容
- */
- private StringgetStringCellValue(HSSFCellcell){
- StringstrCell= "" ;
- switch (cell.getCellType()){
- case HSSFCell.CELL_TYPE_STRING:
- strCell=cell.getStringCellValue();
- break ;
- case HSSFCell.CELL_TYPE_NUMERIC:
- strCell=String.valueOf(cell.getNumericCellValue());
- break ;
- case HSSFCell.CELL_TYPE_BOOLEAN:
- strCell=String.valueOf(cell.getBooleanCellValue());
- break ;
- case HSSFCell.CELL_TYPE_BLANK:
- strCell= "" ;
- break ;
- default :
- strCell= "" ;
- break ;
- }
- if (strCell.equals( "" )||strCell== null ){
- return "" ;
- }
- if (cell== null ){
- return "" ;
- }
- return strCell;
- }
- /**
- *獲取單元格數據內容為日期類型的數據
- *@paramcellExcel單元格
- *@returnString單元格數據內容
- */
- private StringgetDateCellValue(HSSFCellcell){
- Stringresult= "" ;
- try {
- int cellType=cell.getCellType();
- if (cellType==HSSFCell.CELL_TYPE_NUMERIC){
- Datedate=cell.getDateCellValue();
- result=(date.getYear()+ 1900 )+ "-" +(date.getMonth()+ 1 )
- + "-" +date.getDate();
- } else if (cellType==HSSFCell.CELL_TYPE_STRING){
- Stringdate=getStringCellValue(cell);
- result=date.replaceAll( "[年月]" , "-" ).replace( "日" , "" ).trim();
- } else if (cellType==HSSFCell.CELL_TYPE_BLANK){
- result= "" ;
- }
- } catch (Exceptione){
- System.out.println( "日期格式不正確!" );
- e.printStackTrace();
- }
- return result;
- }
- public static void main(String[]args){
- try {
- //對讀取Excel表格標題測試
- InputStreamis= new FileInputStream( "C://Excel表格測試.xls" );
- ExcelReaderexcelReader= new ExcelReader();
- String[]title=excelReader.readExcelTitle(is);
- System.out.println( "獲得Excel表格的標題:" );
- for (Strings:title){
- System.out.print(s+ "" );
- }
- //對讀取Excel表格內容測試
- InputStreamis2= new FileInputStream( "C://Excel表格測試.xls" );
- Map<Integer,String>map=excelReader.readExcelContent(is2);
- System.out.println( "獲得Excel表格的內容:" );
- for ( int i= 1 ;i<=map.size();i++){
- System.out.println(map.get(i));
- }
- } catch (FileNotFoundExceptione){
- System.out.println( "未找到指定路徑的文件!" );
- e.printStackTrace();
- }
- }
- }
通過該類提供的方法就能讀取出Excel表格中的數據,數據讀取出來了,其他的,對這些數據進行怎樣的操作,要靠你另外寫程序去實現,因為該類只提供讀取Excel表格數據的功能。
說明:在該類中有一個getStringCellValue(HSSFCell cell)方法和一個getDateCellValue(HSSFCell cell)方法,前一個方法用于讀取那些為字符串類型的數據,如果你的Excel表格中填寫的是日期類型的數據,則你應該在readExcelContent(InputStream is)方法里調用getDateCellValue(HSSFCell cell)方法,因為若調用getStringCellValue(HSSFCell cell)方法讀取日期類型的數據將得到的是一個浮點數,這很可能不符合實際要求。
更多文章、技術交流、商務合作、聯系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號聯系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元

評論
StringBuffer content = new StringBuffer("");// 文檔內容
HSSFWorkbook workbook = new HSSFWorkbook(new FileInputStream(path));
int sheetCount = workbook.getNumberOfSheets();// excel幾張表
for (int i = 0; i < sheetCount; i++) {// 遍歷excel表
HSSFSheet sheet = workbook.getSheetAt(i);// 對excel的第一個表引用
int rowCount = sheet.getLastRowNum();// 取得最后一行的下標
for (int j = 0; j < rowCount; j++) {// 循環每一行
HSSFRow row = sheet.getRow(j);// 引用行
if (row == null) {
continue;
} else {
short cellNum = row.getLastCellNum();
for (short m = 0; m < cellNum; m++) {
HSSFCell cell = row.getCell(m);// 引用行中的一個單元格
if (cell != null) {
int cellType = cell.getCellType();
// CELL_TYPE_NUMERIC 0 數字
// CELL_TYPE_STRING 1 字符串
// CELL_TYPE_FORMULA 2 公式
// CELL_TYPE_BLANK 3 空格
// CELL_TYPE_BOOLEAN 4 布爾值
// CELL_TYPE_ERROR 5 錯誤
switch (cellType) {
// 單元格類型為數字
case HSSFCell.CELL_TYPE_NUMERIC:
// 取數字單元格的值
double d = cell.getNumericCellValue();
content.append(String.valueOf(d) + " ");
break;
// 單元格類型為字符串
case HSSFCell.CELL_TYPE_STRING:
String str = cell.getStringCellValue().trim();
if (!str.equals("")) {
content.append(str + " ");
}
break;
// 單元格類型為公式
case HSSFCell.CELL_TYPE_FORMULA:
// 不讀取公式
// String formula = cell.getCellFormula();
// content = content + formula+" ";
break;
// 單元格類型為空白
case HSSFCell.CELL_TYPE_BLANK:
break;
// 單元格類型為布爾值
case HSSFCell.CELL_TYPE_BOOLEAN:
// boolean bool = cell.getBooleanCellValue();
// content = content + bool+" ";
break;
// 單元格類型為錯誤
case HSSFCell.CELL_TYPE_ERROR:
// byte errorCode = cell.getErrorCellValue();
// content = content + errorCode+" ";
break;
default:
break;
}
} else {
// content = content + "..." +" ";//沒有數據的單元格使用...填充
}
}
}
content.append("/r");
}
}
return content.toString().trim();
}