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
广告