【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 小时前
Spring 6 的 @HttpExchange 注解:声明式 HTTP 客户端的现代化利器
java·spring·http
野犬寒鸦3 小时前
多级缓存架构:性能与数据一致性的平衡处理(原理及优势详解+项目实战)
java·服务器·redis·后端·缓存
帧栈5 小时前
开发避坑指南(58):Java Stream 按List元素属性分组实战指南
java
Da Da 泓5 小时前
LinkedList模拟实现
java·开发语言·数据结构·学习·算法
海琴烟Sunshine5 小时前
Leetcode 14. 最长公共前缀
java·服务器·leetcode
城管不管6 小时前
Lambda
java
yz17800414106 小时前
window pdf文件批量转高清图片png、jpg
pdf·bash
龙茶清欢6 小时前
5、urbane-commerce 微服务统一依赖版本管理规范
java·运维·微服务
海琴烟Sunshine9 小时前
Leetcode 26. 删除有序数组中的重复项
java·算法·leetcode
RoboWizard9 小时前
移动固态硬盘连接手机无法读取是什么原因?
java·spring·智能手机·电脑·金士顿