iText - 新增表格



本章將介紹如何使用 iText 庫建立一個 PDF 文件並在其中新增表格。

向 PDF 新增表格

您可以透過例項化 **Document** 類來建立一個空的 PDF 文件。例項化此類時,需要將 **PdfDocument** 物件作為引數傳遞給其建構函式。然後,要向文件新增表格,需要例項化 **Table** 類並將此物件使用 **add()** 方法新增到文件中。

以下是建立包含表格的 PDF 文件的步驟。

步驟 1:建立 PdfWriter 物件

**PdfWriter** 類表示 PDF 的 DocWriter。此類屬於 **com.itextpdf.kernel.pdf** 包。此類的建構函式接受一個字串,表示要建立 PDF 檔案的路徑。

透過將字串值(表示您需要建立 PDF 的路徑)傳遞給其建構函式來例項化 **PdfWriter** 類,如下所示。

// Creating a PdfWriter 
String dest = "C:/itextExamples/addingTable.pdf"; 
PdfWriter writer = new PdfWriter(dest);

當此型別的物件傳遞給 PdfDocument(類)時,新增到此文件的每個元素都將寫入指定的檔案。

步驟 2:建立 PdfDocument 物件

**PdfDocument** 類是表示 iText 中 PDF 文件的類。此類屬於 **com.itextpdf.kernel.pdf** 包。要例項化此類(在寫入模式下),需要將 **PdfWriter** 類的物件傳遞給其建構函式。

透過將上面建立的 PdfWriter 物件傳遞給其建構函式來例項化 PdfDocument 類,如下所示。

// Creating a PdfDocument  
PdfDocument pdfDoc = new PdfDocument(writer); 

建立 PdfDocument 物件後,您可以使用其類提供的相應方法新增各種元素,例如頁面、字型、檔案附件和事件處理程式。

步驟 3:建立 Document 物件

**com.itextpdf.layout** 包中的 **Document** 類是建立自包含 PDF 時的根元素。此類的建構函式之一接受 **PdfDocument** 類的物件。

透過傳遞在前面步驟中建立的 **PdfDocument** 類物件來例項化 **Document** 類,如下所示。

// Creating a Document   
Document document = new Document(pdfDoc); 

步驟 4:建立 Table 物件

**Table** 類表示一個二維網格,其中填充按行和列排序的單元格。它屬於 **com.itextpdf.layout.element** 包。

如下所示例項化 **Table** 類。

// Creating a table object 
float [] pointColumnWidths = {150F, 150F, 150F}; 
Table table = new Table(pointColumnWidths); 

步驟 5:向表格新增單元格

透過例項化 **com.itextpdf.layout.element** 包中的 **Cell** 類來建立一個 **cell** 物件。使用此類的 **add()** 方法新增單元格的內容。

最後,要將此單元格新增到表格中,請呼叫 **Table** 類的 **addCell()** 方法並將 **cell** 物件作為引數傳遞給此方法,如下所示。

// Adding cell 1 to the table 
Cell cell1 = new Cell();   // Creating a cell 
cell1.add("Name");         // Adding content to the cell 
table.addCell(cell1);      // Adding cell to the table       

// Adding cell 2 to the table Cell 
cell2 = new Cell();       // Creating a cell 
cell2.add("Raju");        // Adding content to the cell 
table.addCell(cell2);     // Adding cell to the table 

步驟 6:將表格新增到文件

使用 **Document** 類的 **add()** 方法新增上一步中建立的 **table** 物件,如下所示。

// Adding list to the document 
document.add(table);

步驟 7:關閉文件

使用 **Document** 類的 **close()** 方法關閉文件,如下所示。

// Closing the document 
document.close(); 

示例

下面的 Java 程式演示瞭如何使用 iText 庫建立一個 PDF 文件並在其中新增表格。它建立一個名為 **addingTable.pdf** 的 PDF 文件,向其中新增一個表格,並將其儲存到 **C:/itextExamples/** 路徑。

將此程式碼儲存在名為 **AddingTable.java** 的檔案中。

import com.itextpdf.kernel.pdf.PdfDocument; 
import com.itextpdf.kernel.pdf.PdfWriter; 

import com.itextpdf.layout.Document; 
import com.itextpdf.layout.element.Cell; 
import com.itextpdf.layout.element.Table;  

public class AddingTable {      
   public static void main(String args[]) throws Exception {           
      // Creating a PdfDocument object   
      String dest = "C:/itextExamples/addingTable.pdf";   
      PdfWriter writer = new PdfWriter(dest);       
         
      // Creating a PdfDocument object      
      PdfDocument pdf = new PdfDocument(writer);                  
      
      // Creating a Document object       
      Document doc = new Document(pdf);                       
         
      // Creating a table       
      float [] pointColumnWidths = {150F, 150F, 150F};   
      Table table = new Table(pointColumnWidths);    
      
      // Adding cells to the table       
      table.addCell(new Cell().add("Name"));       
      table.addCell(new Cell().add("Raju"));       
      table.addCell(new Cell().add("Id"));       
      table.addCell(new Cell().add("1001"));       
      table.addCell(new Cell().add("Designation"));       
      table.addCell(new Cell().add("Programmer"));                 
         
      // Adding Table to document        
      doc.add(table);                  
         
      // Closing the document       
      doc.close();
      System.out.println("Table created successfully..");   
   }     
}

使用以下命令從命令提示符編譯並執行儲存的 Java 檔案:

javac AddingTable.java 
java AddingTable

執行後,上述程式將建立一個 PDF 文件,顯示以下訊息。

Table created successfully..

如果您驗證指定的路徑,您可以找到建立的 PDF 文件,如下所示。

Adding Table
廣告
© . All rights reserved.