POI操作Excel詳解

一、POI操作Excel方法

POI(Poor Obfuscation Implementation)是一個用於處理Microsoft Office文檔的Java API。在處理Excel中的數據時,POI受到廣泛應用,以下是POI操作Excel的基本方法:

File file = new File("example.xlsx");
Workbook workbook = WorkbookFactory.create(file); // 讀取Excel文件

Sheet sheet = workbook.getSheetAt(0); // 獲取第一個sheet

Row row = sheet.getRow(0); // 獲取第一行

Cell cell = row.getCell(0); // 獲取第一個單元格

cell.setCellValue("Hello World"); // 設置第一個單元格內容

FileOutputStream out = new FileOutputStream(file); // 創建輸出流

workbook.write(out); // 將數據寫入Excel文件

out.close(); // 關閉輸出流

以上代碼實現了使用POI讀取Excel文件、獲取單元格並設置單元格內容,最後將修改後的數據寫入Excel文件。

二、POI操作Excel單元格樣式丟失

在使用POI進行Excel操作時,有時會遇到單元格樣式丟失的問題,下面是解決這個問題的方法:

Cell cell = row.getCell(0);
CellStyle style = cell.getCellStyle(); // 獲取單元格樣式

cell = row.createCell(0); // 創建新單元格
cell.setCellValue("Hello World"); // 設置單元格內容
cell.setCellStyle(style); // 設置單元格樣式

以上代碼獲取了單元格的樣式,然後在創建新的單元格時將樣式設置為舊單元格的樣式,解決了單元格樣式丟失的問題。

三、POI操作Excel導入資料庫

在對Excel數據進行處理後,有時需要將數據導入資料庫進行後續操作,以下是將POI解析出的Excel數據導入MySQL資料庫的示例代碼:

File file = new File("example.xlsx");
Workbook workbook = WorkbookFactory.create(file); // 讀取Excel文件
Sheet sheet = workbook.getSheetAt(0); // 獲取第一個sheet

Class.forName("com.mysql.jdbc.Driver");
Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/test", "root", "password");
Statement stmt = conn.createStatement();
stmt.executeUpdate("CREATE TABLE IF NOT EXISTS example (id INT PRIMARY KEY, name VARCHAR(20))");

String sql = "INSERT INTO example (id, name) VALUES (?, ?)";
PreparedStatement pstmt = conn.prepareStatement(sql);

for (Row row : sheet) {
    if (row.getRowNum() == 0) {
        continue;
    }
    pstmt.setInt(1, (int) row.getCell(0).getNumericCellValue());
    pstmt.setString(2, row.getCell(1).getStringCellValue());
    pstmt.executeUpdate();
}

pstmt.close();
stmt.close();
conn.close();

以上代碼首先連接資料庫並創建表,之後遍歷Excel數據並將數據插入到資料庫中。

四、POI操作Excel表格合併行

有時需要將相鄰單元格合併為一行,以下是合併表格行的示例代碼:

Sheet sheet = workbook.getSheetAt(0);

CellRangeAddress region = new CellRangeAddress(0, 2, 0, 0); // 合併第1列從第1行到第3行的單元格
sheet.addMergedRegion(region);

以上代碼將單元格從第1行到第3行的第1列合併為一行。

五、POI操作Excel讀取第一列

有時需要讀取Excel表格中的特定列,以下是讀取第一列的示例代碼:

Sheet sheet = workbook.getSheetAt(0);

for (Row row : sheet) {
    Cell cell = row.getCell(0);
    if (cell != null) {
        System.out.println(cell.getStringCellValue());
    }
}

以上代碼遍歷第一個sheet的所有行並讀取第一列的數據。

六、POI操作Excel基礎用法詳解

在使用POI進行Excel操作時,還有一些基礎用法需要了解:

  • Workbook:代表整個Excel文檔,可以通過WorkbookFactory來創建。
  • Sheet:代表Excel文檔中的一個sheet。
  • Row:代表一個sheet中的一行。
  • Cell:代表一行中的一個單元格。
  • CellStyle:代表單元格樣式。

其他一些常用的方法包括:

  • setColumnWidth(int columnIndex, int width):設置列寬。
  • getFont(int fontIndex):獲取字體。
  • setBorderBottom(BorderStyle border):設置邊框樣式。
  • setFillForegroundColor(short bgColor):設置填充顏色。

七、POCO操作

POCO(Plain Old CLR Object)是面向對象編程的一種方式,以下是使用POCO操作Excel的示例代碼:

@Data // lombok註解,自動生成getter、setter方法等代碼
public class Person {
    @ExcelProperty(value = {"用戶id"}, index = 0) // easyexcel註解,設置Excel中的列名和順序
    private Long id;

    @ExcelProperty(value = {"用戶名"}, index = 1)
    private String username;

    @ExcelProperty(value = {"狀態"}, index = 2)
    private Integer status;
}

File file = new File("example.xlsx");
EasyExcel.read(file, Person.class, new ReadListener<Person>() {
    // 實現方法
}).sheet().doRead();

以上代碼使用EasyExcel庫實現了使用POCO讀取Excel數據,將Excel中的數據映射到Person類。

八、POI操作PPT

除了Excel,POI也可以用於操作PowerPoint文檔,以下是POI操作PPT的示例代碼:

File file = new File("example.pptx");
XMLSlideShow ppt = new XMLSlideShow(new FileInputStream(file)); // 讀取PPT文件
XSLFSlide slide = ppt.createSlide(); // 創建新slide

XSLFTextBox box = slide.createTextBox(); // 創建文本框
box.setAnchor(new Rectangle(50, 50, 300, 100)); // 設置文本框大小和位置
box.setText("Hello World!"); // 設置文本框內容

FileOutputStream out = new FileOutputStream(file); // 創建輸出流
ppt.write(out); // 將修改後的數據寫入PPT文件
out.close(); // 關閉輸出流

以上代碼實現了使用POI讀取PPT文件,創建新的slide,添加文本框並設置內容,最後將修改後的數據寫入PPT文件。

九、POI操作DOC

POI也可以用於對Word文檔進行操作,以下是POI操作DOC的示例代碼:

File file = new File("example.docx");
XWPFDocument doc = new XWPFDocument(new FileInputStream(file)); // 讀取DOC文件

XWPFParagraph para = doc.createParagraph(); // 創建新段落
XWPFRun run = para.createRun(); // 創建run
run.setText("Hello World!"); // 設置文本內容

FileOutputStream out = new FileOutputStream(file); // 創建輸出流
doc.write(out); // 將修改後的數據寫入DOC文件
out.close(); // 關閉輸出流

以上代碼實現了使用POI讀取Word文檔,創建新段落,添加run並設置內容,最後將修改後的數據寫入Word文檔。

十、POI操作PDF

POI也可以用於對PDF文檔進行操作,以下是POI操作PDF的示例代碼:

File file = new File("example.pdf");
PDDocument doc = PDDocument.load(file); // 讀取PDF文件

PDPage page = doc.getPage(0); // 獲取第一頁

PDPageContentStream contentStream = new PDPageContentStream(doc, page);
contentStream.setFont(PDType1Font.HELVETICA_BOLD, 12); // 設置字體和字型大小
contentStream.beginText(); // 開始文本操作
contentStream.newLineAtOffset(100, 700); // 設置文本起始位置
contentStream.showText("Hello World!"); // 顯示文本
contentStream.endText(); // 結束文本操作
contentStream.close(); // 關閉contentStream

doc.save(file); // 將修改後的數據寫入PDF文件
doc.close(); // 關閉doc

以上代碼實現了使用POI讀取PDF文件,獲取第一頁並添加文本,最後將修改後的數據寫入PDF文件。

原創文章,作者:LPZW,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/147884.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
LPZW的頭像LPZW
上一篇 2024-11-02 13:13
下一篇 2024-11-02 13:13

相關推薦

  • Python棧操作用法介紹

    如果你是一位Python開發工程師,那麼你必須掌握Python中的棧操作。在Python中,棧是一個容器,提供後進先出(LIFO)的原則。這篇文章將通過多個方面詳細地闡述Pytho…

    編程 2025-04-29
  • Python操作數組

    本文將從多個方面詳細介紹如何使用Python操作5個數組成的列表。 一、數組的定義 數組是一種用於存儲相同類型數據的數據結構。Python中的數組是通過列表來實現的,列表中可以存放…

    編程 2025-04-29
  • Python操作MySQL

    本文將從以下幾個方面對Python操作MySQL進行詳細闡述: 一、連接MySQL資料庫 在使用Python操作MySQL之前,我們需要先連接MySQL資料庫。在Python中,我…

    編程 2025-04-29
  • Python磁碟操作全方位解析

    本篇文章將從多個方面對Python磁碟操作進行詳細闡述,包括文件讀寫、文件夾創建、刪除、文件搜索與遍歷、文件重命名、移動、複製、文件許可權修改等常用操作。 一、文件讀寫操作 文件讀寫…

    編程 2025-04-29
  • Python代碼實現迴文數最少操作次數

    本文將介紹如何使用Python解決一道經典的迴文數問題:給定一個數n,按照一定規則對它進行若干次操作,使得n成為迴文數,求最少的操作次數。 一、問題分析 首先,我們需要了解迴文數的…

    編程 2025-04-29
  • 為什麼不能用Microsoft Excel進行Python編程?

    Microsoft Excel是一個廣泛使用的數據分析工具,但是它不能直接用於Python編程。這是因為Microsoft Excel並不是一個編程工具,它的主要功能是進行數據處理…

    編程 2025-04-29
  • Python元祖操作用法介紹

    本文將從多個方面對Python元祖的操作進行詳細闡述。包括:元祖定義及初始化、元祖遍歷、元祖切片、元祖合併及比較、元祖解包等內容。 一、元祖定義及初始化 元祖在Python中屬於序…

    編程 2025-04-29
  • Python列表的讀寫操作

    本文將針對Python列表的讀取與寫入操作進行詳細的闡述,包括列表的基本操作、列表的增刪改查、列表切片、列表排序、列表反轉、列表拼接、列表複製等操作。 一、列表的基本操作 列表是P…

    編程 2025-04-29
  • 如何用Python對數據進行離散化操作

    數據離散化是指將連續的數據轉化為離散的數據,一般是用於數據挖掘和數據分析中,可以幫助我們更好的理解數據,從而更好地進行決策和分析。Python作為一種高效的編程語言,在數據處理和分…

    編程 2025-04-29
  • Python序列的常用操作

    Python序列是程序中的重要工具,在數據分析、機器學習、圖像處理等很多領域都有廣泛的應用。Python序列分為三種:列表(list)、元組(tuple)和字元串(string)。…

    編程 2025-04-28

發表回復

登錄後才能評論