使用POI讀取/創建Execl(.xlsx)文件

来源:http://www.cnblogs.com/liuyanmin/archive/2016/01/20/5146853.html
-Advertisement-
Play Games

最近項目中用到瞭解析Execl表格的功能,在網上百度了一下自己寫了一個小Demo。由於項目中使用的是Execl2007,就是尾碼為.xlsx的,所以只研究瞭解析和創建Execl2007的文件,解析Execl2007和Execl2003有一定的區別,大家在解析的時候要註意。一下是Demo中用到的jar...


最近項目中用到瞭解析Execl表格的功能,在網上百度了一下自己寫了一個小Demo。由於項目中使用的是Execl2007,就是尾碼為.xlsx的,所以只研究瞭解析和創建Execl2007的文件,解析Execl2007和Execl2003有一定的區別,大家在解析的時候要註意。

一下是Demo中用到的jar包(可能有幾個包用不到,懶得刪了):

其他的我就不過多的介紹了,每個方法的具體用法可以參考官方手冊,直接上代碼:

poi文檔和jar包下載地址:http://poi.apache.org/download.html

  1 package com.lym.test;
  2 
  3 import java.io.FileInputStream;
  4 import java.io.FileOutputStream;
  5 import java.io.InputStream;
  6 import java.io.OutputStream;
  7 
  8 import org.apache.poi.hssf.util.HSSFColor;
  9 import org.apache.poi.ss.usermodel.Cell;
 10 import org.apache.poi.ss.usermodel.CellStyle;
 11 import org.apache.poi.ss.usermodel.Font;
 12 import org.apache.poi.ss.usermodel.Row;
 13 import org.apache.poi.ss.usermodel.Workbook;
 14 import org.apache.poi.xssf.usermodel.XSSFSheet;
 15 import org.apache.poi.xssf.usermodel.XSSFWorkbook;
 16 
 17 /**
 18  * 使用POI讀取/創建Execl(2007版.xlsx)文件
 19  * 
 20  * @author 劉彥民
 21  *
 22  */
 23 public class POIReaderExecl {
 24 
 25     public static void main(String[] args) throws Exception {
 26 
 27          readExeclFile();
 28 //        createExeclFile();
 29     }
 30 
 31     /**
 32      * 創建Execl文件
 33      * 
 34      * @throws Exception
 35      */
 36     public static void createExeclFile() throws Exception {
 37         // 創建工作空間
 38         XSSFWorkbook wb = new XSSFWorkbook();
 39         // 創建工作表
 40         XSSFSheet sheet = wb.createSheet("testdata");
 41         // 創建標題行(第一行)
 42         Row row0 = sheet.createRow(0);
 43         // 創建列
 44         for (int i = 0; i < 11; i++) {
 45             Cell cell_1 = row0.createCell(i, Cell.CELL_TYPE_STRING);// 第一個參數:列數(從0開始),第二個參數:列類型
 46             // 設置單元格樣式
 47             CellStyle style = getStyle(wb);
 48             cell_1.setCellStyle(style);
 49             cell_1.setCellValue("Hello Column" + i);
 50             // 設置自動調整大小
 51             sheet.autoSizeColumn(i);
 52         }
 53         for (int rowNum = 1; rowNum < 200; rowNum++) {
 54             Row row = sheet.createRow(rowNum);
 55             for (int i = 0; i < 11; i++) {
 56                 Cell cell = row.createCell(i, Cell.CELL_TYPE_STRING);
 57                 cell.setCellValue("cell(" + String.valueOf(rowNum + 1) +", "+ String.valueOf(i + 1) + ")");
 58             }
 59         }
 60         OutputStream out = new FileOutputStream("D://data.xlsx");
 61         wb.write(out);
 62         out.flush();
 63         out.close();
 64     }
 65 
 66     /**
 67      * 讀取Execl文件
 68      * 
 69      * @throws Exception
 70      */
 71     public static void readExeclFile() throws Exception {
 72         // 創建輸入流
 73         InputStream in = new FileInputStream("D://order.xlsx");
 74         // 創建工作空間
 75         XSSFWorkbook wb = new XSSFWorkbook(in);
 76         // 獲取工作表
 77         XSSFSheet sheet = wb.getSheetAt(0);// 獲取第一個工作表
 78         // 獲取總行數
 79         int rowNums = sheet.getLastRowNum();
 80         // 獲取總列數
 81         int colNums = sheet.getPhysicalNumberOfRows();
 82         // 工作行
 83         Row row = null;
 84         // 工作單元格
 85         Cell cell = null;
 86 
 87         System.out.println("總行數:" + rowNums);
 88         System.out.println("總列數:" + colNums);
 89         // 迴圈遍歷每行的內容
 90         for (int i = 1; i <= rowNums; i++) {
 91             // 獲取第i行的工作行,第0行是列頭,所以從第1行開始
 92             row = sheet.getRow(i);
 93             // 獲取每個單元格的值
 94             for (int j = 0; j < colNums; j++) {
 95                 cell = row.getCell(j);
 96                 cell.setCellType(Cell.CELL_TYPE_STRING);
 97                 System.out.print(cell.toString() + "        ");
 98             }
 99             System.out.println();
100         }
101     }
102 
103     /**
104      * 設置單元格樣式
105      */
106     public static CellStyle getStyle(Workbook workbook) {
107 
108         CellStyle style = workbook.createCellStyle();
109         style.setAlignment(CellStyle.ALIGN_CENTER);
110         style.setVerticalAlignment(CellStyle.VERTICAL_CENTER);
111         // 設置單元格字體
112         Font headerFont = workbook.createFont(); // 字體
113         headerFont.setFontHeightInPoints((short) 14);
114         headerFont.setColor(HSSFColor.RED.index);
115         headerFont.setFontName("宋體");
116         style.setFont(headerFont);
117         style.setWrapText(true);
118 
119         // 設置單元格邊框及顏色
120         style.setBorderBottom((short) 1);
121         style.setBorderLeft((short) 1);
122         style.setBorderRight((short) 1);
123         style.setBorderTop((short) 1);
124         style.setWrapText(true);
125         return style;
126     }
127 
128 }

讀取order.xlsx文件的內容:

生成data.xlsx文件的內容:

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

-Advertisement-
Play Games
更多相關文章
  • BuildPath中只支持加入jar文件,具體方法如下:在eclips里在工程名上右鍵->build path->contigure bud path->java build path里有個libraries->add external jars = 增加工程外部的包add jars = 增加工程內...
  • 1.django安裝在http://www.djangoproject.com/download/這個網站上可以下載django的最新版本。在下載時,要註意django版本和本機安裝的Python版本是匹配的。在這個https://docs.djangoproject.com/en/dev/faq/...
  • 環境:smarty1.在http://www.smarty.net/download下載最新smarty包,window選擇zips,linux下選擇tar.gz。以windows為例,下載後解壓,如f:\smarty。2.把解壓出來的smarty目錄里lib目錄拷貝到test里,重命名為smart...
  • 指針是C語言的靈魂,我想對於一級指針大家應該都很熟悉,也經常用到:比如說對於字元串的處理,函數參數的“值,結果傳遞”等,對於二級指針或者多級指針,我想理解起來也是比較容易的,比如二級指針就是指向指針的指針.....n級指針就是....但是可能大家比較不容易理解的是,二級指針或者多級指針用在哪裡呢?怎...
  • /** * 遍歷list的方法 * @param args */ public static void main(String[] args) { List list = new ArrayList(); list.add("111"); ...
  • 對於初學者朋友,在OC指針指針修改對象屬性掌握起來一般問題不大的,但是要再來幾個"函數"和你"折騰"呢?哈哈!看看你又沒有中過槍吧!看下麵一段代碼:void test1(int newAge,double newHeight);void test2(Person *newP);void tes...
  • 1. Callable、Future、RunnableFuture、FutureTask的繼承關係 在多線程編程中,我們一般通過一個實現了Runnable介面的對象來創建一個線程,這個線程在內部會執行Runnable對象的run方法。如果說我們創建一個線程來完成某項工作,希望在完成以後該線程能夠返回...
  • 一、字典(dict) 1. 概述 字典是Python唯一的映射類型。 只能使用不可變的對象(比如字元串)來作為字典的鍵,但是可以把不可變或可變的對象作為字典的值。 鍵值對在字典中以這樣的方式標記:d = key1 : value1, key2 : value2 。註意它們的鍵/值...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...