• Java实现Excel转PDF的两种方法总结


    hello,你好呀,我是,一个超会写bug的程序猿!

    使用具将Excel转为PDF的方法有很多,在这里我给大家介绍两种常用的方法,分别应对两种不一样的使用场景,接下来我在springboot环境下给大家做一下演示!

    一、使用spire转化PDF

    首先介绍一种比较简单的方法,这种方法可以使用短短的几行代码就可以将我们的Excel文件中的某一个sheet页或者整个Excel文件转为PDF格式,

    但是这种方法有一个缺点就是这个jar包是收费的,只能导出3个sheet页,不适合有多个sheet页的Excel文件的转换。

    使用时首先在pom文件中导入workbook的所需依赖:

             
                 e-iceblue
                 spire.xls.free
                 2.2.0
             
    
    • 1
    • 2
    • 3
    • 4
    • 5

    1、使用spire将整个Excel文件转为PDF

    使用workbook导出整个Excel文件的代码只需要两步,我们可以直接看代码示例:

         /**
          * 使用spire简单整个Excel转换为pdf
          *
          * @param inputFilePath Excel文件路径
          * @param outputFilePath 导出的PDF文件路径
          */
         public static void totalExcelToPDF(String inputFilePath, String outputFilePath) {
             Workbook wb = new Workbook();
     //        引入Excel文件
             wb.loadFromFile(inputFilePath);
     //        导出PDF文件
             wb.saveToFile(outputFilePath, FileFormat.PDF);
         }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13

    2、指定单个的sheet页转为PDF

    使用spire可以将指定单个sheet页面转为PDF格式输出,在这里需要输入指定的sheet页的下标。代码示例如下:

         /**
          * 使用spire将单个sheet转成pdf
          *
          * @param inputFilePath Excel文件路径
          * @param outputFilePath 导出的PDF文件路径
          * @param sheetNum 导出的sheet页下标
          */
         public static void partExcelToPDF(String inputFilePath, String outputFilePath, int sheetNum) {
             //加载Excel文档
             Workbook wb = new Workbook();
             wb.loadFromFile(inputFilePath);
             //获取到哪一个sheet页
             Worksheet sheet = wb.getWorksheets().get(sheetNum);
             //调用方法保存为PDF格式
             sheet.saveToPdf(outputFilePath);
         }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16

    以上使用spire来实现Excel转换PDF的方法虽然简单,但是不适合于较大的Excel文件转化,只适合有小于3个sheet页的文件使用。

    所以在企业项目开发中,如果想要将大批量的Excel文件或sheet页较多的Excel文件整体转化为PDF格式的话,还是推荐使用下面这种方法,而且这种方法使用稳定还免费!

    二、使用jacob实现Excel转PDF(推荐使用)

    1、环境准备

    在使用jacob之前需要做一些准备,首先需要去下载jacob的压缩包jacob.zip ,下载地址:https://sourceforge.net/projects/jacob-project/

    解压之后,得到如下内容:

    img

    如果你是64位系统就用 x64的dll,32位系统就用x86的dll。之后我们需要将dll文件放入放入你的jdk的bin目录下,如下图所示:

    img

    这样前期准备工作就做好了,

    接下来在在Maven中引入Jacob所需依赖:

             
             
                 com.jacob
                 jacob
                 1.19
                 system
                 
                 D:DevInstalljacob18,19jacob-1.19jacob.jar
             
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    注意:上面依赖中标签的值就是你的jacob.jar的具体路径,这个改成自己刚才下载的对应的路径就行了。

    2、执行导出PDF

    执行Excel导出PDF的方法如下:其中比较重要的地方进行了注释,方法可以直接拿来用即可!

     ?
         /**
          * 使用jacob实现excel转PDF
          *
          * @param inputFilePath 导入Excel文件路径
          * @param outputFilePath 导出PDF文件路径
          */
         public static void jacobExcelToPDF(String inputFilePath, String outputFilePath) {
             ActiveXComponent ax = null;
             Dispatch excel = null;
     ?
             try {
                 ComThread.InitSTA();
                 ax = new ActiveXComponent("Excel.Application");
                 ax.setProperty("Visible", new Variant(false));
    		 	//禁用宏
                 ax.setProperty("AutomationSecurity", new Variant(3));
     ?
                 Dispatch excels = ax.getProperty("Workbooks").toDispatch();
     ?
                 Object[] obj = {
                         inputFilePath,
                         new Variant(false),
                         new Variant(false)
                 };
     ?
                 excel = Dispatch.invoke(excels, "Open", Dispatch.Method, obj, new int[9]).toDispatch();
     ?
     			//转换格式
                 Object[] obj2 = {
                         //PDF格式等于0
                         new Variant(0),
                         outputFilePath,
                         //0=标准(生成的PDF图片不会模糊),1=最小的文件
                         new Variant(0)
                 };
     ?
                 Dispatch.invoke(excel, "ExportAsFixedFormat", Dispatch.Method, obj2, new int[1]);
     ?
             } catch (Exception e) {
                 e.printStackTrace();
                 throw e;
             } finally {
                 if (excel != null) {
                     Dispatch.call(excel, "Close", new Variant(false));
                 }
                 if (ax != null) {
                     ax.invoke("Quit", new Variant[]{});
                     ax = null;
                 }
                 ComThread.Release();
             }
     ?
     ?
         }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55

    以上就是在Java中将Excel导出为PDF最常用的两种方法了,推荐使用第二种!

    我是,我们下期见!

    先自我介绍一下,小编13年上师交大毕业,曾经在小公司待过,去过华为OPPO等大厂,18年进入阿里,直到现在。深知大多数初中级java工程师,想要升技能,往往是需要自己摸索成长或是报班学习,但对于培训机构动则近万元的学费,着实压力不小。自己不成体系的自学效率很低又漫长,而且容易碰到天花板技术停止不前。因此我收集了一份《java开发全套学习资料》送给大家,初衷也很简单,就是希望帮助到想自学又不知道该从何学起的朋友,同时减轻大家的负担。添加下方名片,即可获取全套学习资料哦

  • 相关阅读:
    Qt——多线程
    【MySQL】MySQL 5.7 的生命周期将于2023年结束,大家来拥抱 MySQL 5.8 吧
    Linux 安装 Nginx 并配置为系统服务(超详细)
    hadoop详解
    缓存问题对软件测试工作的影响
    编译添加了ALPHA开发板的NXP官方uboot
    产品团队的需求验证和确认
    PICO首届XR开发者挑战赛正式启动,助推行业迈入“VR+MR”新阶段
    springboot学生成绩课堂表现过程性评价系统java
    Jackson ImmunoResearch 过敏测试
  • 原文地址:https://blog.csdn.net/begefefsef/article/details/126106780