使用Java实现Excel转PDF的示例详解

 更新时间:2025年02月10日 10:19:10   作者:五行星辰  
在实际的开发过程中,我们常常会遇到需要将 Excel 文件转换为 PDF 文件的需求,本文为大家介绍一种Java中的常见实现方式,需要的可以参考一下

在实际的开发过程中,我们常常会遇到需要将 Excel 文件转换为 PDF 文件的需求。Java 提供了多种库和工具来实现这个功能,下面我将为你介绍一种常见的实现方式,使用 Apache POI 读取 Excel 文件,再使用 iText 生成 PDF 文件。

1. 引入所需的库

首先,我们需要在项目中引入 Apache POI 和 iText 相关的库。如果你使用的是 Maven 项目,就在 pom.xml 文件里添加以下依赖:

<!-- Apache POI 用于读取 Excel 文件 -->
<dependency>
    <groupId>org.apache.poi</groupId>
    <artifactId>poi</artifactId>
    <version>5.2.3</version>
</dependency>
<dependency>
    <groupId>org.apache.poi</groupId>
    <artifactId>poi-ooxml</artifactId>
    <version>5.2.3</version>
</dependency>
 
<!-- iText 用于生成 PDF 文件 -->
<dependency>
    <groupId>com.itextpdf</groupId>
    <artifactId>itextpdf</artifactId>
    <version>5.5.13.3</version>
</dependency>

2. 实现 Excel 转 PDF 的代码

下面是具体的 Java 代码示例:

import com.itextpdf.text.*;
import com.itextpdf.text.pdf.PdfPCell;
import com.itextpdf.text.pdf.PdfPTable;
import com.itextpdf.text.pdf.PdfWriter;
import org.apache.poi.ss.usermodel.*;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;
 
import java.io.*;
 
public class ExcelToPdfConverter {
    public static void main(String[] args) {
        try {
            // 读取 Excel 文件
            FileInputStream excelFile = new FileInputStream("input.xlsx");
            Workbook workbook = new XSSFWorkbook(excelFile);
            Sheet sheet = workbook.getSheetAt(0);
 
            // 创建 PDF 文档
            Document document = new Document();
            PdfWriter.getInstance(document, new FileOutputStream("output.pdf"));
            document.open();
 
            // 创建 PDF 表格,列数与 Excel 表格的列数相同
            int columnCount = sheet.getRow(0).getLastCellNum();
            PdfPTable pdfTable = new PdfPTable(columnCount);
 
            // 遍历 Excel 表格的每一行
            for (Row row : sheet) {
                // 遍历当前行的每一个单元格
                for (Cell cell : row) {
                    // 获取单元格的值
                    String cellValue = getCellValueAsString(cell);
                    // 创建 PDF 表格的单元格
                    PdfPCell pdfCell = new PdfPCell(new Phrase(cellValue));
                    // 将单元格添加到 PDF 表格中
                    pdfTable.addCell(pdfCell);
                }
            }
 
            // 将 PDF 表格添加到 PDF 文档中
            document.add(pdfTable);
 
            // 关闭文档和 Excel 文件
            document.close();
            workbook.close();
            excelFile.close();
 
            System.out.println("Excel 转 PDF 成功!");
        } catch (Exception e) {
            e.printStackTrace();
            System.out.println("Excel 转 PDF 失败:" + e.getMessage());
        }
    }
 
    // 将单元格的值转换为字符串
    private static String getCellValueAsString(Cell cell) {
        if (cell == null) {
            return "";
        }
        switch (cell.getCellType()) {
            case STRING:
                return cell.getStringCellValue();
            case NUMERIC:
                if (DateUtil.isCellDateFormatted(cell)) {
                    return cell.getDateCellValue().toString();
                } else {
                    return String.valueOf(cell.getNumericCellValue());
                }
            case BOOLEAN:
                return String.valueOf(cell.getBooleanCellValue());
            case FORMULA:
                return cell.getCellFormula();
            default:
                return "";
        }
    }
}

3. 代码详细解释

1.读取 Excel 文件:

  • FileInputStream excelFile = new FileInputStream("input.xlsx");:创建一个 FileInputStream 对象,用于读取 input.xlsx 文件。
  • Workbook workbook = new XSSFWorkbook(excelFile);:使用 XSSFWorkbook 类创建一个 Workbook 对象,用于表示 Excel 文件。
  • Sheet sheet = workbook.getSheetAt(0);:获取 Excel 文件的第一个工作表。

2.创建 PDF 文档:

  • Document document = new Document();:创建一个 Document 对象,用于表示 PDF 文档。
  • PdfWriter.getInstance(document, new FileOutputStream("output.pdf"));:使用 PdfWriter 将 Document 对象与 FileOutputStream 关联起来,指定生成的 PDF 文件名为 output.pdf。
  • document.open();:打开 PDF 文档,准备写入内容。

3.创建 PDF 表格:

  • int columnCount = sheet.getRow(0).getLastCellNum();:获取 Excel 表格第一行的列数。
  • PdfPTable pdfTable = new PdfPTable(columnCount);:创建一个 PdfPTable 对象,用于表示 PDF 表格,列数与 Excel 表格的列数相同。

4.遍历 Excel 表格并填充 PDF 表格:

  • for (Row row : sheet) {... }:遍历 Excel 表格的每一行。
  • for (Cell cell : row) {... }:遍历当前行的每一个单元格。
  • String cellValue = getCellValueAsString(cell);:调用 getCellValueAsString 方法将单元格的值转换为字符串。
  • PdfPCell pdfCell = new PdfPCell(new Phrase(cellValue));:创建一个 PdfPCell 对象,用于表示 PDF 表格的单元格。
  • pdfTable.addCell(pdfCell);:将 PdfPCell 对象添加到 PdfPTable 中。

5.将 PDF 表格添加到 PDF 文档中:

document.add(pdfTable);:将 PdfPTable 对象添加到 Document 中。

6.关闭文档和 Excel 文件:

document.close(); workbook.close(); excelFile.close();:关闭 PDF 文档、Excel 文件和输入流,释放资源。

4. 注意事项

上述代码仅处理了 Excel 文件的第一个工作表,如果需要处理多个工作表,可以使用 workbook.getNumberOfSheets() 方法获取工作表的数量,然后遍历每个工作表进行处理。

代码中的 getCellValueAsString 方法用于将不同类型的单元格值转换为字符串,确保在处理不同类型的单元格时不会出现异常。

到此这篇关于使用Java实现Excel转PDF的示例详解的文章就介绍到这了,更多相关Java Excel转PDF内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 使用SpringBoot发送邮箱验证码的简单实现

    使用SpringBoot发送邮箱验证码的简单实现

    这篇文章主要介绍了使用SpringBoot发送邮箱验证码的简单实现,咱们今天来讲使用QQ邮箱来发送和接收验证码,首先来介绍一下它在SpringBoot项目中的具体应用,需要的朋友可以参考下
    2023-04-04
  • IDEA插件指南之Mybatis log插件安装及使用方法

    IDEA插件指南之Mybatis log插件安装及使用方法

    这篇文章主要给大家介绍了关于IDEA插件指南之Mybatis log插件安装及使用的相关资料,文中通过图文介绍的非常详细,对大家的学习或者工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2024-02-02
  • Java中SSM+Shiro系统登录验证码的实现方法

    Java中SSM+Shiro系统登录验证码的实现方法

    这篇文章主要介绍了 SSM+Shiro系统登录验证码的实现方法,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2017-02-02
  • Java实战之多线程模拟站点售票

    Java实战之多线程模拟站点售票

    今天带大家来练习Java实战,文中多线程模拟站点售票这个问题作了详细的介绍,对正在学习java的小伙伴们有很好地帮助,需要的朋友可以参考下
    2021-05-05
  • springboot整合mybatis分页拦截器的问题小结

    springboot整合mybatis分页拦截器的问题小结

    springboot整合mybatis分页拦截器,分页拦截实际上就是获取sql后将sql拼接limit,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
    2021-07-07
  • 详细聊聊Mybatis中万能的Map

    详细聊聊Mybatis中万能的Map

    最近有个需求,就是使用mybatis时,向mysql中插入数据,其参数为map类型,下面这篇文章主要给大家介绍了关于Mybatis中万能的Map的相关资料,需要的朋友可以参考下
    2021-12-12
  • 关于java的九个预定义Class对象

    关于java的九个预定义Class对象

    这篇文章主要介绍了关于java的九个预定义Class对象,在Java中,没有类就无法做任何事情。然而,并不是所有的类都具有面向对象特征。如Math.random,并只需要知道方法名和参数,需要的朋友可以参考下
    2023-05-05
  • 详解java中finalize的实现与相应的执行过程

    详解java中finalize的实现与相应的执行过程

    在常规的java书籍中,即会描述 object的finalize方法是用于一些特殊的对象在回收之前再做一些扫尾的工作,但是并没有说明此是如何实现的.本篇从java的角度(不涉及jvm以及c++),有需要的朋友们可以参考借鉴。
    2016-09-09
  • SpringBoot参数校验之@Validated的使用详解

    SpringBoot参数校验之@Validated的使用详解

    这篇文章主要通过示例为大家详细介绍一下介绍了SpringBoot参数校验中@Validated的使用方法,文中的示例代码讲解详细,需要的可以参考一下
    2022-06-06
  • 基于Mybatis-plus实现多租户架构的全过程

    基于Mybatis-plus实现多租户架构的全过程

    多租户是一种软件架构技术,在多用户的环境下,共有同一套系统,并且要注意数据之间的隔离性,下面这篇文章主要给大家介绍了关于基于Mybatis-plus实现多租户架构的相关资料,需要的朋友可以参考下
    2022-02-02

最新评论