欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

java如何讀取Excel簡單模板

 更新時(shí)間:2018年10月20日 15:27:45   作者:Bour  
這篇文章主要為大家詳細(xì)介紹了java如何讀取Excel簡單模板,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

場景:對于經(jīng)常需要導(dǎo)入Excel模板或數(shù)據(jù)來解析后加以應(yīng)用的,使用頻率非常之高,做了一個(gè)比較穩(wěn)定的版本,體現(xiàn)在這些地方

工具:org.apache.poi

使用前必須了解這些:

1、要解析,那肯定先判斷是不是Excel

2、xls后綴的Excel,是03版及以前的用HSSFWorkbook類
      xlsx后綴的Excel,是07版及以后的用XSSFWorkbook解析

3、getWorkbook這個(gè)方法是我自己亂造各種Excel數(shù)據(jù)不斷測試搜索修正得出的結(jié)果,其他的像簡單的判斷后綴xls還是xlsx來決定用HSSH還是XSSF是不保險(xiǎn)的,比如你可能沒遇過org.apache.poi.openxml4j.exceptions.InvalidFormatException這樣的異常,當(dāng)然這個(gè)異常仍然是因?yàn)镋xcel類型導(dǎo)致獲取workbook時(shí)出錯(cuò),然而我查到的結(jié)果是,Excel最底層是xml實(shí)現(xiàn)的,類型問題出在這兒,看異常的描述也可以稍微看出來openxml4j.exceptions

4 、可能出現(xiàn)空行,空的單元格,或者單元格值為空的情況,這些情況,在我的readExcel()方法里都考慮到了,為什么我不用迭代器,或者加強(qiáng)的for each循環(huán)?就是因?yàn)檫@些坑爹的空單元格或者空行啊,迭代器內(nèi)部在取cell單元格對象時(shí)跳過這些空的對象,who knows why?我也不知道,反正我測試過,跳過去了,本來5個(gè)單元格,一個(gè)空的,結(jié)果就只得到4個(gè)數(shù)據(jù),即使用cell.isEmpty()和cell!=null來判斷,也沒卵用,因?yàn)楸闅v的時(shí)候直接跳過去了,都沒有判斷的機(jī)會

5、取單元格數(shù)據(jù),這個(gè)就比較簡單了,判斷單元格類型,根據(jù)類型做相應(yīng)的處理取出來,但是我覺得我這個(gè)getCellValue()的方法應(yīng)該有漏洞,先這么用著

下面上代碼,簡單描述下關(guān)鍵部位

import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.io.InputStream;
import java.io.PushbackInputStream;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.Map;
import java.util.List;
import org.apache.poi.POIXMLDocument;
import org.apache.poi.openxml4j.exceptions.InvalidFormatException;
import org.apache.poi.openxml4j.opc.OPCPackage;
import org.apache.poi.poifs.filesystem.POIFSFileSystem;
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 org.apache.poi.xssf.usermodel.XSSFWorkbook;
import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.xmlbeans.impl.piccolo.io.FileFormatException;
/**
 *yanbiao 2016.10.25 
 */
public class ExcelUtil {
 
  private static final String EXTENSION_XLS = "xls";
  private static final String EXTENSION_XLSX = "xlsx";

/**
* 文件檢查
*/
private void preReadCheck(String filePath) throws FileNotFoundException, FileFormatException {

File file = new File(filePath);
if (!file.exists()) {
throw new FileNotFoundException("導(dǎo)入的文件不存在:" + filePath);
}
if (!(filePath.endsWith(EXTENSION_XLS) || filePath.endsWith(EXTENSION_XLSX))) {
throw new FileFormatException("傳入的文件不是excel");
}
} 
 /**
   * 取得WorkBook對象
   * xls:HSSFWorkbook,03版
   * xlsx:XSSFWorkbook,07版
  */
 private Workbook getWorkbook(String filePath) throws IOException, InvalidFormatException { 
    //直接判斷后綴來返回相應(yīng)的Workbook對象多數(shù)情況沒問題,但是這個(gè)更保險(xiǎn),第3條已經(jīng)說明  
    Workbook wb = null;
    InputStream is = new FileInputStream(filePath);
    if (!is.markSupported()) {
      is = new PushbackInputStream(is, 8);
    }
    if (POIFSFileSystem.hasPOIFSHeader(is)) {
       return new HSSFWorkbook(is);
    }
    if (POIXMLDocument.hasOOXMLHeader(is)) {
      return new XSSFWorkbook(OPCPackage.open(is));
    }
    throw new IllegalArgumentException("您的excel版本目前不支持poi解析");
  }
 
  /**
   * 讀取excel文件內(nèi)容
   */
  public Map<Integer, List<String>> readExcel(String filePath) throws FileNotFoundException, FileFormatException {
    // 檢查和獲取workbook對象
    this.preReadCheck(filePath);
    Workbook wb = null;
    Map<Integer,List<String>> map = new HashMap<Integer, List<String>>();
    try {
      wb = this.getWorkbook(filePath);
      // 默認(rèn)只讀取第一個(gè)sheet 
      Sheet sheet = wb.getSheetAt(0);
      int rowcount = sheet.getLastRowNum();//邏輯行,包括空行
      int cellcount = sheet.getRow(0).getLastCellNum();//第一行(將來作為字段的行)有多少個(gè)單元格
      for (int i=0;i<rowcount;i++) {          //這里用最原始的for循環(huán)來保證每行都會被讀取
         List<String> list = new ArrayList<String>();
         Row row = sheet.getRow(i);
         if(null!=row){
            for (int j=0;j<cellcount;j++) {
             list.add(getCellValue(row.getCell(j)));  //這里也是用for循環(huán),用Cell c:row這樣的遍歷,空單元格就被拋棄了  
            }
            System.out.println("第"+(row.getRowNum()+1)+"行數(shù)據(jù):"+list.toString());
            map.put(row.getRowNum(), list); 
          }else{
            for (int j=0;j<cellcount;j++) {
              list.add("無數(shù)據(jù)");   
            }
            System.out.println("第"+(i+1)+"行數(shù)據(jù):"+list.toString());
            map.put(i, list);
        }     
      }    
    } catch (Exception e) {
        System.out.println("讀取Excel異常:"+e.getMessage());
        e.printStackTrace();
      } finally {
         if (wb != null) {
           try {
               wb.close();
            } catch (IOException e) {
               e.printStackTrace();
             }
         }
       }
    return map;   
  }
  /**
   * 取單元格的值
   */
  private String getCellValue(Cell c) {
    if (c == null) {
      return "無數(shù)據(jù)";
    }
    String value = "";
    switch (c.getCellType()){
    case HSSFCell.CELL_TYPE_NUMERIC://數(shù)字
       value = c.getNumericCellValue()+"";
    break;
    case HSSFCell.CELL_TYPE_STRING://字符串
      value = c.getStringCellValue();
    break;
    case HSSFCell.CELL_TYPE_BOOLEAN://boolean
      value = c.getBooleanCellValue()+"";
    break;
    case HSSFCell.CELL_TYPE_FORMULA://公式
      value = c.getCellFormula()+"";
    break;
    case HSSFCell.CELL_TYPE_BLANK://空值
      value= "無數(shù)據(jù)";
     break;
    case HSSFCell.CELL_TYPE_ERROR:
      value = "非法字符";
     break;
    default:
      value= "未知類型";
     break;    
    }
    return value;
  }
}

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Java接口測試Cookie與token原理解析

    Java接口測試Cookie與token原理解析

    這篇文章主要介紹了Java接口測試Cookie與token原理解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-04-04
  • 測試springboot項(xiàng)目出現(xiàn)Test Ignored的解決

    測試springboot項(xiàng)目出現(xiàn)Test Ignored的解決

    這篇文章主要介紹了測試springboot項(xiàng)目出現(xiàn)Test Ignored的解決,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-11-11
  • java讀取resource目錄下文件的方法示例

    java讀取resource目錄下文件的方法示例

    這篇文章主要介紹了利用java讀取resource目錄下文件的方法,文中給出了詳細(xì)的示例代碼,相信對大家具有一定的參考借鑒,需要的朋友們下面來一起看看吧。
    2017-02-02
  • Java中求Logn/log2 的精度問題

    Java中求Logn/log2 的精度問題

    這篇文章主要介紹了Java中求Logn/log2 的精度問題,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-08-08
  • java后臺發(fā)起get請求獲取響應(yīng)數(shù)據(jù)

    java后臺發(fā)起get請求獲取響應(yīng)數(shù)據(jù)

    這篇文章主要為大家詳細(xì)介紹了java后臺發(fā)起get請求獲取響應(yīng)數(shù)據(jù),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-08-08
  • springboot的logging.group日志分組方法源碼流程解析

    springboot的logging.group日志分組方法源碼流程解析

    這篇文章主要為大家介紹了springboot的logging.group日志分組方法源碼流程解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-12-12
  • 非常適合新手學(xué)生的Java線程池優(yōu)化升級版

    非常適合新手學(xué)生的Java線程池優(yōu)化升級版

    作者是一個(gè)來自河源的大三在校生,以下筆記都是作者自學(xué)之路的一些淺薄經(jīng)驗(yàn),如有錯(cuò)誤請指正,將來會不斷的完善筆記,幫助更多的Java愛好者入門
    2022-03-03
  • 基于MapReduce實(shí)現(xiàn)決策樹算法

    基于MapReduce實(shí)現(xiàn)決策樹算法

    這篇文章主要為大家詳細(xì)介紹了基于MapReduce實(shí)現(xiàn)決策樹算法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-08-08
  • Java編寫實(shí)現(xiàn)登陸窗口

    Java編寫實(shí)現(xiàn)登陸窗口

    這篇文章主要為大家詳細(xì)介紹了Java編寫實(shí)現(xiàn)登陸窗口,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • Java中Synchronized鎖的使用和原理詳解

    Java中Synchronized鎖的使用和原理詳解

    這篇文章主要介紹了Java中Synchronized鎖的使用和原理詳解,synchronized是?Java?內(nèi)置的關(guān)鍵字,它提供了一種獨(dú)占的加鎖方式,synchronized的獲取和釋放鎖由JVM實(shí)現(xiàn),用戶不需要顯示的釋放鎖,非常方便,需要的朋友可以參考下
    2023-07-07

最新評論