【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 的逻辑。

相关推荐
橙子199110169 分钟前
Kotlin 中的 Unit 类型的作用以及 Java 中 Void 的区别
java·开发语言·kotlin
yours_Gabriel16 分钟前
【登录认证】JWT令牌
java·开发语言·redis
为美好的生活献上中指22 分钟前
java每日精进 5.11【WebSocket】
java·javascript·css·网络·sql·websocket·网络协议
qq_141826973228 分钟前
python通过curl访问deepseek的API调用案例
java·数据库·python
lyw20561930 分钟前
微服务八股(自用)
java·开发语言
液态不合群38 分钟前
理解 C# 中的各类指针
java·开发语言·c#
一只码代码的章鱼40 分钟前
Java Spring MVC -01
java·spring·mvc
Persistence___1 小时前
SpringBoot中的拦截器
java·spring boot·后端
嘵奇1 小时前
Spring Boot 跨域问题全解:原理、解决方案与最佳实践
java·spring boot·后端
黄雪超1 小时前
JVM——方法内联之去虚化
java·开发语言·jvm