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

JavaWeb使用POI操作Excel文件實例

 更新時間:2017年04月28日 16:54:03   作者:feipeng8848  
這篇文章主要介紹了JavaWeb使用POI操作Excel文件,需要的朋友可以參考下

1.為項目添加POI

POI官網(wǎng)鏈接

點進(jìn)去之后下載(上邊的是編譯好的類,下邊的是源代碼)

 解壓文件夾,把下面三個文件復(fù)制到WebComtent>WEB-INF>lib文件夾下

再把這三個文件復(fù)制到Tomcat的lib文件夾下,否則Tomcat會因為找不到類而報錯(這個地方郁悶了一上午)

讀取“.xls”格式使用  import org.apache.poi.hssf.usermodel.*;包的內(nèi)容,例如:HSSFWorkbook

讀取“.xlsx”格式使用 import org.apache.poi.xssf.usermodel.*; 包的內(nèi)容,例如:XSSFWorkbook

讀取兩種格式使用    import org.apache.poi.ss.usermodel.*    包的內(nèi)容,例如:Workbook

由于我是讀取xslx文件所以使用以上幾個jar文件。

注意:

上圖中的兩個文件夾中也有我們需要的jar文件,具體是哪幾個忘記了(當(dāng)然為了保險也可以把所有的都放進(jìn)WebContent>WEN-INF>lib下再BuildPath進(jìn)項目),沒關(guān)系,一會運(yùn)行的過程中會報錯,根據(jù)錯誤信息再去找到相關(guān)的jar文件BuildPath進(jìn)去就好,注意還要再Tomcat>lib下放置一份副本。

2.讀取Excel文件

官方教程:鏈接

類庫:鏈接

直接看代碼吧,不難懂。

//遍歷一個Excel文件<br>private void getExcelData(File file) {
  System.out.println("now in getExcelData" );
  System.out.println("get file name:"+file.getName().toString());
  XSSFWorkbook workBook= null;
  try {
   workBook = new XSSFWorkbook(file);
   int sheetCount = workBook.getNumberOfSheets(); //Sheet的數(shù)量
   System.out.println("num of sheet is : "+sheetCount);
   //遍歷每個sheet
   for(int i=0;i<sheetCount;i++)
   {
    XSSFSheet sheet = workBook.getSheetAt(i);
    //獲取總行數(shù)
    int rowCount = sheet.getPhysicalNumberOfRows();
    System.out.println("num of row : "+ rowCount);
    System.out.println("i now in sheet : "+ i);
    //遍歷每一行 
    for (int r = 0; r < rowCount; r++) {
     XSSFRow row = sheet.getRow(r); 
     //獲取總列數(shù) 
     int cellCount = row.getPhysicalNumberOfCells();
     //遍歷每一列 
      for (int c = 0; c < cellCount; c++) {
       XSSFCell cell = row.getCell(c);
       String cellValue = null;
       switch (cell.getCellTypeEnum()) {
      case STRING:
       //System.out.println("celltype is string");
       cellValue = cell.getStringCellValue(); 
       break;
      case NUMERIC:
       //System.out.println("celltype is Number");//整數(shù),小數(shù),日期
       cellValue = String.valueOf(cell.getNumericCellValue());
       break;
      case BOOLEAN:
       //System.out.println("celltype is Boolean");
       cellValue = String.valueOf(cell.getBooleanCellValue()); 
       break;
      case FORMULA:
       //System.out.println("celltype is Formula");//公式
       cellValue = "錯誤,不能為公式"; 
       break;
      case BLANK:
       //System.out.println("celltype is Blank");//空白
       cellValue = cell.getStringCellValue();
       break;
      case ERROR:
       //System.out.println("celltype is Error");
       cellValue = "錯誤"; 
       break;
      default:
       //System.out.println("celltype : default");
       cellValue = "錯誤";
       break;       
      }
       System.out.println(cellValue.toString());
      }
    }
   }
  } catch (IOException e) {
   System.out.println("File Error IOException : "+e.getMessage());
  } 
  catch (Exception e) {
   // TODO: handle exception
  }
  finally {
   try {
    workBook.close();
      } catch (Exception e) {
    // TODO Auto-generated catch block
    e.printStackTrace();
    System.out.println("workBook.close()&fileInputStream.close() Error : "+e.getMessage());  
   }
   System.out.println("Try Catch : finally");   
  }
  System.out.println("hi feipeng8848 getExcelData is done");
 }

以上所述是小編給大家介紹的JavaWeb使用POI操作Excel文件實例,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關(guān)文章

  • 應(yīng)用啟動數(shù)據(jù)初始化接口CommandLineRunner和Application詳解

    應(yīng)用啟動數(shù)據(jù)初始化接口CommandLineRunner和Application詳解

    這篇文章主要介紹了應(yīng)用啟動數(shù)據(jù)初始化接口CommandLineRunner和Application詳解,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-12-12
  • Java指令重排引發(fā)問題及解決方案

    Java指令重排引發(fā)問題及解決方案

    指令重排是JVM在解釋執(zhí)行Java代碼時對指令順序進(jìn)行重新排列的一種優(yōu)化技術(shù),本文主要介紹了Java指令重排引發(fā)問題及解決方案,感興趣的可以了解一下
    2023-08-08
  • Java日志軟件Log4j的基本使用教程

    Java日志軟件Log4j的基本使用教程

    這篇文章主要介紹了Java日志軟件Log4j的基本使用教程,包括回滾和發(fā)送日志郵件等基本功能使用的講解,需要的朋友可以參考下
    2015-12-12
  • 簡單聊聊Java程序中的換行符

    簡單聊聊Java程序中的換行符

    Java程序中的換行符一般使用“\n”表示,它是一個轉(zhuǎn)義字符,表示換行符。根據(jù)操作系統(tǒng)的不同,換行符的實際表示可能不同,本文就來簡單聊聊他們的區(qū)別與使用吧
    2023-03-03
  • 使用java判斷輸入年份是否為閏年完整代碼

    使用java判斷輸入年份是否為閏年完整代碼

    閏年的引入確保了我們的日歷與地球運(yùn)行軌道的對齊,使得時間的計算更加準(zhǔn)確,在編程中判斷給定年份是否為閏年是一項常見的任務(wù),這篇文章主要給大家介紹了關(guān)于使用java判斷輸入年份是否為閏年的相關(guān)資料,需要的朋友可以參考下
    2023-10-10
  • Java中獲取Class對象的3種方式代碼示例

    Java中獲取Class對象的3種方式代碼示例

    Class對象是反射的核心,通過他可以調(diào)用類的任意方法,下面這篇文章主要給大家介紹了關(guān)于Java中獲取Class對象的3種方式,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2024-07-07
  • java處理異常Exception的方法總結(jié)

    java處理異常Exception的方法總結(jié)

    在Java中處理異常并不是一個簡單的事情,不僅僅初學(xué)者很難理解,即使一些有經(jīng)驗的開發(fā)者也需要花費(fèi)很多時間,本文為大家整理了java處理異常Exception的一些常用方法,希望對大家有所幫助
    2023-09-09
  • Java多線程實現(xiàn)異步調(diào)用的方法

    Java多線程實現(xiàn)異步調(diào)用的方法

    本文給大家分享java多線程實現(xiàn)異步調(diào)用的方法,感興趣的朋友跟著腳本之家小編一起學(xué)習(xí)吧
    2015-09-09
  • Spring中@Scope的幾種取值方式

    Spring中@Scope的幾種取值方式

    這篇文章主要介紹了Spring中@Scope的幾種取值方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-06-06
  • SpringBoot集成FastDFS依賴實現(xiàn)文件上傳的示例

    SpringBoot集成FastDFS依賴實現(xiàn)文件上傳的示例

    這篇文章主要介紹了SpringBoot集成FastDFS依賴實現(xiàn)文件上傳,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-05-05

最新評論