javaWeb使用POI操作Excel

来源:http://www.cnblogs.com/feipeng8848/archive/2017/04/28/6781822.html
-Advertisement-
Play Games

1.為項目添加POI POI官網鏈接 點進去之後下載(上邊的是編譯好的類,下邊的是源代碼) 解壓文件夾,把下麵三個文件複製到WebComtent>WEB-INF>lib文件夾下 再把這三個文件複製到Tomcat的lib文件夾下,否則Tomcat會因為找不到類而報錯(這個地方鬱悶了一上午) 讀取“.x ...


1.為項目添加POI

POI官網鏈接

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

 

 解壓文件夾,把下麵三個文件複製到WebComtent>WEB-INF>lib文件夾下

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

讀取“.xls”格式使用  import org.apache.poi.hssf.usermodel.*;包的內容,例如:HSSFWorkbook
讀取“.xlsx”格式使用 import org.apache.poi.xssf.usermodel.*; 包的內容,例如:XSSFWorkbook
讀取兩種格式使用    import org.apache.poi.ss.usermodel.*    包的內容,例如:Workbook

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

註意:

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

2.讀取Excel文件

官方教程:鏈接

 

類庫:鏈接 

直接看代碼吧,不難懂。

//遍歷一個Excel文件
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的數量 System.out.println("num of sheet is : "+sheetCount); //遍歷每個sheet for(int i=0;i<sheetCount;i++) { XSSFSheet sheet = workBook.getSheetAt(i); //獲取總行數 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); //獲取總列數 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");//整數,小數,日期 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"); }

  

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 裝飾器模式詳解地址 原文總結 定義: 在不必改變原類文件和使用繼承的情況下, 動態的擴展一個對象的功能. 通過創建一個包裝對象, 也就是裝飾來包裹真實的對象 部分詳解提示 看了一些文檔, 裝飾器模式非常依賴構造器 與 重寫方法 裝飾器模式的特點: 不改變原來的類 , 不使用繼承 , 動態擴展 流這塊 ...
  • 本篇博客我們繼續的來聊SpringMVC的東西,下方我們將會聊到js、css這些靜態文件的載入配置,以及伺服器推送的兩種實現方式。當然我們在伺服器推送時,會用到jQuery的東西,所以我們先聊一下如何載入靜態資源文件,然後我們再聊如何實現伺服器推送。 下方給出了兩種實現伺服器推送的方式,一種是SSE ...
  • Hibernate的二級緩存 理解緩存定義: 緩存(Cache):電腦領域非常通用的概念。它介於應用程式和永久性數據存儲源(如硬碟上的文件或者資料庫)之間,其作用是降低應用程式直接讀寫永久性數據存儲源的頻率,從而提高應用的運行性能。緩存中的數據是數據存儲源中數據的拷貝。緩存的物理介質通常是記憶體。 ...
  • 使用 RegexString.with(string).pattern(pattern).start() + 後續操作(matches,find或者是replace) 源碼 示例 ...
  • 經過了一段時間的學習,慢慢的計入到了python的列表、元組的學習了,這一部分是後面函數的基礎,這也是無論何種語言都要學習的部分。其實過程很辛苦,不過對於小白的我不見得是一件壞事,反正都看不懂,倒也沒有什麼心理負擔。想想學成後的一覽眾山小,此時的積累,便是每一步都要堅實的。 列表、元組 列表是我們最 ...
  • 函數, get()與setdefault(), lambda表達式,三元運算, 遍歷list與dict的方法. ...
  • 對編程語言比較熟悉的朋友,應該知道“反射”這個機制。Python作為一門動態語言,當然不會缺少這一重要功能。然而,在網路上卻很少見到有詳細或者深刻的剖析論文。下麵結合一個web路由的實例來闡述python的反射機制的使用場景和核心本質。 一、前言 在上面的代碼中,我們必須區分兩個概念,f1和“f1" ...
  • 讀這本書,前後算作一次半吧。第一次讀時,到了第八課的形態學處理部分時荒棄了,當時也沒有養成做筆記的習慣,導致最後不了了之。後來在去年12月份左右重新撿起這本書,並且堅持在閱讀的同時多看源碼多做筆記,最終於4月底完成閱讀與學習。 目前我對這本書的看法是,著重介紹灰度圖像處理的基礎知識,包括基本的bmp ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...