亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

打造自己的讀取Excel數(shù)據(jù)的工具類

系統(tǒng) 2665 0

在實(shí)際應(yīng)用中經(jīng)常需要把Excel表格數(shù)據(jù)導(dǎo)入到數(shù)據(jù)庫,為此需求本人寫了一個(gè)讀取Excel數(shù)據(jù)的java類,現(xiàn)將代碼貼出來與大家一起分享。

該類提供兩個(gè)方法,一個(gè)方法用于讀取Excel表格的表頭,另一個(gè)方法用于讀取Excel表格的內(nèi)容。

(注:本類需要POI組件的支持,POI是apache組織下的一個(gè)開源組件,)

代碼如下:

Java代碼
  1. package org.hnylj.poi.util;
  2. import java.io.FileInputStream;
  3. import java.io.FileNotFoundException;
  4. import java.io.IOException;
  5. import java.io.InputStream;
  6. import java.util.Date;
  7. import java.util.HashMap;
  8. import java.util.Map;
  9. import org.apache.poi.hssf.usermodel.HSSFCell;
  10. import org.apache.poi.hssf.usermodel.HSSFRow;
  11. import org.apache.poi.hssf.usermodel.HSSFSheet;
  12. import org.apache.poi.hssf.usermodel.HSSFWorkbook;
  13. import org.apache.poi.poifs.filesystem.POIFSFileSystem;
  14. /**
  15. *操作Excel表格的功能類
  16. *@author:hnylj
  17. *@version1.0
  18. */
  19. public class ExcelReader{
  20. private POIFSFileSystemfs;
  21. private HSSFWorkbookwb;
  22. private HSSFSheetsheet;
  23. private HSSFRowrow;
  24. /**
  25. *讀取Excel表格表頭的內(nèi)容
  26. *@paramInputStream
  27. *@returnString表頭內(nèi)容的數(shù)組
  28. *
  29. */
  30. public String[]readExcelTitle(InputStreamis){
  31. try {
  32. fs= new POIFSFileSystem(is);
  33. wb= new HSSFWorkbook(fs);
  34. } catch (IOExceptione){
  35. e.printStackTrace();
  36. }
  37. sheet=wb.getSheetAt( 0 );
  38. row=sheet.getRow( 0 );
  39. //標(biāo)題總列數(shù)
  40. int colNum=row.getPhysicalNumberOfCells();
  41. String[]title= new String[colNum];
  42. for ( int i= 0 ;i<colNum;i++){
  43. title[i]=getStringCellValue(row.getCell(( short )i));
  44. }
  45. return title;
  46. }
  47. /**
  48. *讀取Excel數(shù)據(jù)內(nèi)容
  49. *@paramInputStream
  50. *@returnMap包含單元格數(shù)據(jù)內(nèi)容的Map對(duì)象
  51. */
  52. public Map<Integer,String>readExcelContent(InputStreamis){
  53. Map<Integer,String>content= new HashMap<Integer,String>();
  54. Stringstr= "" ;
  55. try {
  56. fs= new POIFSFileSystem(is);
  57. wb= new HSSFWorkbook(fs);
  58. } catch (IOExceptione){
  59. e.printStackTrace();
  60. }
  61. sheet=wb.getSheetAt( 0 );
  62. //得到總行數(shù)
  63. int rowNum=sheet.getLastRowNum();
  64. row=sheet.getRow( 0 );
  65. int colNum=row.getPhysicalNumberOfCells();
  66. //正文內(nèi)容應(yīng)該從第二行開始,第一行為表頭的標(biāo)題
  67. for ( int i= 1 ;i<=rowNum;i++){
  68. row=sheet.getRow(i);
  69. int j= 0 ;
  70. while (j<colNum){
  71. //每個(gè)單元格的數(shù)據(jù)內(nèi)容用"-"分割開,以后需要時(shí)用String類的replace()方法還原數(shù)據(jù)
  72. //也可以將每個(gè)單元格的數(shù)據(jù)設(shè)置到一個(gè)javabean的屬性中,此時(shí)需要新建一個(gè)javabean
  73. str+=getStringCellValue(row.getCell(( short )j)).trim()+ "-" ;
  74. j++;
  75. }
  76. content.put(i,str);
  77. str= "" ;
  78. }
  79. return content;
  80. }
  81. /**
  82. *獲取單元格數(shù)據(jù)內(nèi)容為字符串類型的數(shù)據(jù)
  83. *@paramcellExcel單元格
  84. *@returnString單元格數(shù)據(jù)內(nèi)容
  85. */
  86. private StringgetStringCellValue(HSSFCellcell){
  87. StringstrCell= "" ;
  88. switch (cell.getCellType()){
  89. case HSSFCell.CELL_TYPE_STRING:
  90. strCell=cell.getStringCellValue();
  91. break ;
  92. case HSSFCell.CELL_TYPE_NUMERIC:
  93. strCell=String.valueOf(cell.getNumericCellValue());
  94. break ;
  95. case HSSFCell.CELL_TYPE_BOOLEAN:
  96. strCell=String.valueOf(cell.getBooleanCellValue());
  97. break ;
  98. case HSSFCell.CELL_TYPE_BLANK:
  99. strCell= "" ;
  100. break ;
  101. default :
  102. strCell= "" ;
  103. break ;
  104. }
  105. if (strCell.equals( "" )||strCell== null ){
  106. return "" ;
  107. }
  108. if (cell== null ){
  109. return "" ;
  110. }
  111. return strCell;
  112. }
  113. /**
  114. *獲取單元格數(shù)據(jù)內(nèi)容為日期類型的數(shù)據(jù)
  115. *@paramcellExcel單元格
  116. *@returnString單元格數(shù)據(jù)內(nèi)容
  117. */
  118. private StringgetDateCellValue(HSSFCellcell){
  119. Stringresult= "" ;
  120. try {
  121. int cellType=cell.getCellType();
  122. if (cellType==HSSFCell.CELL_TYPE_NUMERIC){
  123. Datedate=cell.getDateCellValue();
  124. result=(date.getYear()+ 1900 )+ "-" +(date.getMonth()+ 1 )
  125. + "-" +date.getDate();
  126. } else if (cellType==HSSFCell.CELL_TYPE_STRING){
  127. Stringdate=getStringCellValue(cell);
  128. result=date.replaceAll( "[年月]" , "-" ).replace( "日" , "" ).trim();
  129. } else if (cellType==HSSFCell.CELL_TYPE_BLANK){
  130. result= "" ;
  131. }
  132. } catch (Exceptione){
  133. System.out.println( "日期格式不正確!" );
  134. e.printStackTrace();
  135. }
  136. return result;
  137. }
  138. public static void main(String[]args){
  139. try {
  140. //對(duì)讀取Excel表格標(biāo)題測(cè)試
  141. InputStreamis= new FileInputStream( "C://Excel表格測(cè)試.xls" );
  142. ExcelReaderexcelReader= new ExcelReader();
  143. String[]title=excelReader.readExcelTitle(is);
  144. System.out.println( "獲得Excel表格的標(biāo)題:" );
  145. for (Strings:title){
  146. System.out.print(s+ "" );
  147. }
  148. //對(duì)讀取Excel表格內(nèi)容測(cè)試
  149. InputStreamis2= new FileInputStream( "C://Excel表格測(cè)試.xls" );
  150. Map<Integer,String>map=excelReader.readExcelContent(is2);
  151. System.out.println( "獲得Excel表格的內(nèi)容:" );
  152. for ( int i= 1 ;i<=map.size();i++){
  153. System.out.println(map.get(i));
  154. }
  155. } catch (FileNotFoundExceptione){
  156. System.out.println( "未找到指定路徑的文件!" );
  157. e.printStackTrace();
  158. }
  159. }
  160. }

通過該類提供的方法就能讀取出Excel表格中的數(shù)據(jù),數(shù)據(jù)讀取出來了,其他的,對(duì)這些數(shù)據(jù)進(jìn)行怎樣的操作,要靠你另外寫程序去實(shí)現(xiàn),因?yàn)樵擃愔惶峁┳x取Excel表格數(shù)據(jù)的功能。

說明:在該類中有一個(gè)getStringCellValue(HSSFCell cell)方法和一個(gè)getDateCellValue(HSSFCell cell)方法,前一個(gè)方法用于讀取那些為字符串類型的數(shù)據(jù),如果你的Excel表格中填寫的是日期類型的數(shù)據(jù),則你應(yīng)該在readExcelContent(InputStream is)方法里調(diào)用getDateCellValue(HSSFCell cell)方法,因?yàn)槿粽{(diào)用getStringCellValue(HSSFCell cell)方法讀取日期類型的數(shù)據(jù)將得到的是一個(gè)浮點(diǎn)數(shù),這很可能不符合實(shí)際要求。

評(píng)論
public static String readXls(String path) throws Exception {
StringBuffer content = new StringBuffer("");// 文檔內(nèi)容
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);// 對(duì)excel的第一個(gè)表引用
int rowCount = sheet.getLastRowNum();// 取得最后一行的下標(biāo)
for (int j = 0; j < rowCount; j++) {// 循環(huán)每一行
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);// 引用行中的一個(gè)單元格
if (cell != null) {
int cellType = cell.getCellType();
// CELL_TYPE_NUMERIC 0 數(shù)字
// CELL_TYPE_STRING 1 字符串
// CELL_TYPE_FORMULA 2 公式
// CELL_TYPE_BLANK 3 空格
// CELL_TYPE_BOOLEAN 4 布爾值
// CELL_TYPE_ERROR 5 錯(cuò)誤
switch (cellType) {
// 單元格類型為數(shù)字
case HSSFCell.CELL_TYPE_NUMERIC:
// 取數(shù)字單元格的值
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;
// 單元格類型為錯(cuò)誤
case HSSFCell.CELL_TYPE_ERROR:
// byte errorCode = cell.getErrorCellValue();
// content = content + errorCode+" ";
break;
default:
break;
}
} else {
// content = content + "..." +" ";//沒有數(shù)據(jù)的單元格使用...填充
}
}
}
content.append("/r");
}
}
return content.toString().trim();
}

打造自己的讀取Excel數(shù)據(jù)的工具類


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號(hào)聯(lián)系: 360901061

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對(duì)您有幫助就好】

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對(duì)您有幫助,請(qǐng)用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長(zhǎng)會(huì)非常 感謝您的哦!!!

發(fā)表我的評(píng)論
最新評(píng)論 總共0條評(píng)論
主站蜘蛛池模板: 婷婷的久久五月综合先锋影音 | 四虎成人永久地址 | 久久精品日日躁夜夜躁欧美 | 深夜免费网站 | 亚洲人成绝费网站色ww | 日本不卡免费高清视频 | 亚洲精品久一区 | 国产大片中文字幕 | 免费福利网站在线观看 | 国产精品久久久久久爽爽爽 | 久久综合给合久久97色美利坚 | 日韩中文在线观看 | 成人精品一区二区久久久 | 九九热视频在线免费观看 | 黄色成人在线网站 | 国产国产成人人免费影院 | 天天射天天射天天干 | 国产一区二区精品久久凹凸 | 久久这里有精品视频任我鲁 | 2021久久精品国产99国产 | 国产精品视频在线观看 | h片在线看| 久一视频在线观看 | 欧美专区在线播放 | 国产一级影片 | 草草第一页 | 中文字幕日本在线观看 | 91糖心| 亚洲综合免费 | 亚洲精品在线视频观看 | 欧美成人免费全网站大片 | 2020国产免费久久精品99 | 特级无码a级毛片特黄 | 国产一区二区三区在线免费观看 | 免费一级毛片在线播放视频 | 天天操天天草 | 欧美成人三级视频 | a毛毛片| 久久精品道一区二区三区 | 久久99精品久久久久久国产人妖 | 久久综合九色 |