📅  最后修改于: 2020-10-16 02:48:41             🧑  作者: Mango
在本章中,我们将了解如何使用iText库创建PDF文档并向其中添加表格。
您可以通过实例化Document类来创建一个空的PDF Document。在实例化此类时,您需要将PdfDocument对象作为参数传递给其构造函数。然后,要将表添加到文档中,您需要实例化Table类,并使用add()方法将此对象添加到文档中。
以下是创建带有表格的PDF文档的步骤。
PdfWriter类表示PDF的DocWriter。此类属于包com.itextpdf.kernel.pdf 。此类的构造函数接受一个字符串,该字符串表示要在其中创建PDF的文件的路径。
实例化PdfWriter类,方法是将一个字符串值(代表您需要在其中创建PDF的路径)传递给它的构造函数,如下所示。
// Creating a PdfWriter
String dest = "C:/itextExamples/addingTable.pdf";
PdfWriter writer = new PdfWriter(dest);
当此类型的对象传递到PdfDocument(类)时,添加到此文档的每个元素都将被写入指定的文件。
PdfDocument类是表示iText中PDF文档的类。此类属于包com.itextpdf.kernel.pdf 。要实例化此类(以编写模式),您需要将PdfWriter类的对象传递给其构造函数。
通过将上面创建的PdfWriter对象传递给其构造函数来实例化PdfDocument类,如下所示。
// Creating a PdfDocument
PdfDocument pdfDoc = new PdfDocument(writer);
创建PdfDocument对象后,您可以使用其类提供的相应方法添加各种元素,如页面,字体,文件附件和事件处理程序。
包com.itextpdf.layout的Document类是创建自足PDF的根元素。此类的构造函数之一接受PdfDocument类的对象。
通过传递在先前步骤中创建的PdfDocument类的对象来实例化Document类,如下所示。
// Creating a Document
Document document = new Document(pdfDoc);
Table类代表一个二维网格,其中填充有按行和列排序的单元。它属于包com.itextpdf.layout.element 。
实例化Table类,如下所示。
// Creating a table object
float [] pointColumnWidths = {150F, 150F, 150F};
Table table = new Table(pointColumnWidths);
通过实例化com.itextpdf.layout.element包的Cell类来创建单元对象。使用此类的add()方法添加单元格的内容。
最后,要将此单元格添加到表中,请调用Table类的addCell()方法,并将单元格对象作为参数传递给此方法,如下所示。
// 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
如下所示,使用Document类的add()方法添加在上一步中创建的表对象。
// Adding list to the document
document.add(table);
使用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文档,如下所示。