Apache POI用法示例詳解
一、Apache POI是什么
Apache POI是用Java編寫的免費開源的跨平臺的Java API,Apache POI提供API給Java程序?qū)icrosoft Office格式檔案讀和寫的功能,其中使用最多的就是使用POI操作Excel文件。
二、POI結(jié)構(gòu)
HSSF - 提供讀寫Microsoft Excel XLS格式檔案的功能
XSSF - 提供讀寫Microsoft Excel OOXML XLSX格式檔案的功能
HWPF - 提供讀寫Microsoft Word DOC格式檔案的功能
HSLF - 提供讀寫Microsoft PowerPoint格式檔案的功能
HDGF - 提供讀Microsoft Visio格式檔案的功能
HPBF - 提供讀Microsoft Publisher格式檔案的功能
HSMF - 提供讀Microsoft Outlook格式檔案的功能
三、POI操作Excel
3.1從Excel讀取數(shù)據(jù)
//通過遍歷工作表獲得行,遍歷行獲得單元格,最終獲取單元格中的值。 //創(chuàng)建工作簿 XSSFWorkbook workbook = new XSSFWorkbook("D:\\hello.xlsx"); //獲取工作表,既可以根據(jù)工作表的順序獲取,也可以根據(jù)工作表的名稱獲取 XSSFSheet sheet = workbook.getSheetAt(0); //遍歷工作表獲得行對象 for (Row row : sheet) { //遍歷行對象獲取單元格對象 for (Cell cell : row) { //獲得單元格中的值 String value = cell.getStringCellValue(); System.out.println(value); } } workbook.close();
POI操作Excel表格封裝了幾個核心對象:
XSSFWorkbook:工作簿 XSSFSheet:工作表 Row:行 Cell:單元格
3.2向Excel文件寫入數(shù)據(jù)
使用POI可以在內(nèi)存中創(chuàng)建一個Excel文件并將數(shù)據(jù)寫入到這個文件,最后通過輸出流將內(nèi)存中的Excel文件下載到磁盤
import org.apache.poi.xssf.usermodel.XSSFWorkbook; import org.apache.poi.xssf.usermodel.XSSFSheet; import org.apache.poi.xssf.usermodel.XSSFRow; import org.apache.poi.xssf.usermodel.XSSFCell; import java.io.FileOutputStream; import java.io.IOException; public class ExcelWriter { public static void main(String[] args) { // 創(chuàng)建一個新的XSSFWorkbook對象,代表整個Excel工作簿 XSSFWorkbook workbook = new XSSFWorkbook(); try { // 創(chuàng)建一個新的工作表 XSSFSheet sheet = workbook.createSheet("Sheet1"); // 創(chuàng)建第一行 XSSFRow row = sheet.createRow(0); // 創(chuàng)建第一行的第一個單元格,并設(shè)置值 XSSFCell cell = row.createCell(0); cell.setCellValue("Hello, World!"); // 創(chuàng)建第二行 XSSFRow row2 = sheet.createRow(1); // 創(chuàng)建第二行的第一個單元格,并設(shè)置值 XSSFCell cell2 = row2.createCell(0); cell2.setCellValue("這是第二行"); // 將工作簿寫入到文件中 try (FileOutputStream outputStream = new FileOutputStream("output.xlsx")) { workbook.write(outputStream); } System.out.println("Excel文件已成功創(chuàng)建并寫入數(shù)據(jù)"); } catch (IOException e) { e.printStackTrace(); } finally { try { // 關(guān)閉workbook if (workbook != null) { workbook.close(); } } catch (IOException e) { e.printStackTrace(); } } } }
四、POI操作Word
4.1讀取 Word 文件
Apache POI 也可以用于讀取 Word 文件的內(nèi)容。
import org.apache.poi.xwpf.extractor.XWPFWordExtractor; import org.apache.poi.xwpf.usermodel.XWPFDocument; import java.io.FileInputStream; import java.io.IOException; public class WordReader { public static void main(String[] args) { try (FileInputStream fis = new FileInputStream("example.docx"); XWPFDocument document = new XWPFDocument(fis)) { XWPFWordExtractor extractor = new XWPFWordExtractor(document); String text = extractor.getText(); System.out.println(text); } catch (IOException e) { e.printStackTrace(); } } }
4.2寫入 Word 文件
寫入 Word 文件也可以通過 Apache POI 來實現(xiàn)。
import org.apache.poi.xwpf.usermodel.*; import java.io.FileOutputStream; import java.io.IOException; public class WordWriter { public static void main(String[] args) { // 創(chuàng)建文檔 XWPFDocument document = new XWPFDocument(); // 創(chuàng)建段落 XWPFParagraph paragraph = document.createParagraph(); XWPFRun run = paragraph.createRun(); run.setText("這是一個示例文檔。"); // 寫入文件 try (FileOutputStream fos = new FileOutputStream("output.docx")) { document.write(fos); } catch (IOException e) { e.printStackTrace(); } } }
五、深入學(xué)習(xí)
如果想要深入學(xué)習(xí) Apache POI,可以參考官方文檔:https://poi.apache.org/
到此這篇關(guān)于Apache POI用法示例詳解的文章就介紹到這了,更多相關(guān)Apache POI用法內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Windows下 Apache PHP 環(huán)境搭建的方法
經(jīng)常在 Linux 環(huán)境下搭建 php 環(huán)境,在 windows 下還是第一次,沒啥技術(shù)含量,就是記錄一下,需要的朋友參考下本教程2017-01-01Ubuntu 18.04上安裝 phpMyAdmin的詳細教程
這篇文章主要介紹了Ubuntu 18.04上安裝 phpMyAdmin的詳細教程,本文通過圖文并茂的形式給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下2019-12-12如何通過其他主機查看Apahce服務(wù)器的運行狀態(tài)
這篇文章主要介紹了如何通過其他主機查看Apahce服務(wù)器的運行狀態(tài),需要的朋友可以參考下2016-04-04Apache Shiro 使用手冊(四) Realm 實現(xiàn)
在認證、授權(quán)內(nèi)部實現(xiàn)機制中都有提到,最終處理都將交給Real進行處理。因為在Shiro中,最終是通過Realm來獲取應(yīng)用程序中的用戶、角色及權(quán)限信息的2014-06-06CentOS8.0 網(wǎng)絡(luò)配置的實現(xiàn)
這篇文章主要介紹了CentOS8.0 網(wǎng)絡(luò)配置的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-10-10