【Excel & PDF 系列】iText 库直接实现表格 PDF

你知道的越多,你不知道的越多

点赞再看,养成习惯

如果您有疑问或者见解,欢迎指教:

企鹅:869192208

文章目录

        • 前言
        • [生成表格 PDF 效果](#生成表格 PDF 效果)
        • [引入 pom 配置](#引入 pom 配置)
        • 代码实现
            • [定义 CreateExcelToPdfModel 对象](#定义 CreateExcelToPdfModel 对象)
            • 主方法
前言

最近遇到生成 Excel 并转 PDF 的需求,磕磕碰碰总结三种方式,分别是 POI + iText 库,EasyExcel + iText 库和直接生成 PDF 表格三种方式。

本文基于 iText 库实现,直接生成表格的 PDF 文件。

生成表格 PDF 效果
引入 pom 配置
xml 复制代码
<dependency>
    <groupId>com.itextpdf</groupId>
    <artifactId>itextpdf</artifactId>
    <version>5.5.13</version>
</dependency>
代码实现
定义 CreateExcelToPdfModel 对象
java 复制代码
import lombok.Data;
import java.util.List;

/**
 * <h2>生成excel表格型的pdf入参</h2>
 * @author chendw
 * @date 2024-02-25 10:12:51
 **/
@Data
public class CreateExcelToPdfModel {

    //表头数据
    private List<List<String>> head;
    //表的内容数据
    private List<List<String>> dataList;
    //PDF表头标题
    private String sheetName;

}
主方法
java 复制代码
import lombok.extern.slf4j.Slf4j;

@Slf4j
public class TablePdfUtil {
  public static void createTablePdf(CreateExcelToPdfModel createExcelToPdfModel, String pdfFilePath) {
    try (FileOutputStream fos = new FileOutputStream(pdfFilePath)) {
      List<List<String>> headList = createExcelToPdfModel.getHead();
      List<List<String>> dataList = createExcelToPdfModel.getDataList();
      // 创建PDF文档对象
      Document document = new Document(PageSize.A2, 50, 50, 50, 50);

      // 创建PDF输出流
      PdfWriter writer = PdfWriter.getInstance(document, fos);

      // 打开PDF文档
      document.open();

      // 创建PDF表格对象
      PdfPTable table = new PdfPTable(headList.size());
      table.setHeaderRows(1);

      // 设置表格宽度
      table.setWidthPercentage(100);

      // 设置表格标题
      String sheetName = createExcelToPdfModel.getSheetName();
      Paragraph title = new Paragraph(sheetName, new Font(BaseFont.createFont("STSong-Light", "UniGB-UCS2-H", BaseFont.NOT_EMBEDDED), 16, Font.BOLD));
      title.setAlignment(Element.ALIGN_CENTER);
      document.add(title);

      // 添加表格标题
      for (List<String> head : headList) {
        String value = head.get(0);
        PdfPCell pdfCell = new PdfPCell(new Paragraph(value, new Font(BaseFont.createFont("STSong-Light", "UniGB-UCS2-H", BaseFont.NOT_EMBEDDED), 12)));
        pdfCell.setBorderWidth(1f);
        pdfCell.setBorderColor(BaseColor.BLACK);
        pdfCell.setPadding(5f);
        pdfCell.setBackgroundColor(BaseColor.LIGHT_GRAY);
        table.addCell(pdfCell);
      }

      // 添加表格内容
      for (List<String> data : dataList) {
        for (String s : data){
          PdfPCell pdfCell = new PdfPCell(new Paragraph(s, new Font(BaseFont.createFont("STSong-Light", "UniGB-UCS2-H", BaseFont.NOT_EMBEDDED), 12)));
          pdfCell.setBorderWidth(1f);
          pdfCell.setBorderColor(BaseColor.BLACK);
          pdfCell.setPadding(5f);
          table.addCell(pdfCell);
        }
      }

      // 添加表格到PDF文档
      table.setSpacingBefore(20f);
      table.setSpacingAfter(20f);
      table.setKeepTogether(true);
      document.add(table);

      // 关闭PDF文档
      document.close();
    } catch (Exception e) {
      log.error("生成表格pdf失败:{}", e.getMessage(), e);
    }
  }
}

至此,就基于 iText 库直接实现了表格 PDF 的逻辑。

相关推荐
发际线还在1 分钟前
互联网大厂Java面试场景故事与技术解析
java·面试·技术栈·技术解析·互联网大厂·代码案例
iPadiPhone2 分钟前
性能之基:Java IO 体系深度解析、面试陷阱与实战指南
java·开发语言·后端·面试
于先生吖4 分钟前
前后端分离开发 Java 跑腿系统:用户 + 骑手 + 后台三端实战
java·开发语言
云烟成雨TD5 分钟前
Spring AI Alibaba 1.x 系列【2】架构、特性与生产级演示案例
java·人工智能·spring
iPadiPhone6 分钟前
Java NIO 核心原理解析、性能调优与大厂面试精要
java·后端·面试·nio
皙然6 分钟前
深度解析三色标记算法:JVM 并发 GC 的核心底层逻辑
java·jvm·算法
大写的老王6 分钟前
OpenClaw 部署实战:一周完成 PHP 到 Java 的项目迁移
java·php·ai编程
hnlgzb10 分钟前
Gemini:kotlin这几个类型有什么区别?类比java的文件,是怎样的?
java·开发语言·kotlin
温酒斟与你11 分钟前
idea编辑器新版UI回归旧版
java·ide·intellij-idea
God__is__a__girl12 分钟前
IntelliJ IDEA 启动失败问题解决记录
java·ide·intellij-idea