通过jacob将excel转成pdf

定义:

Jacob:它允许在java中调用COM接口自动组件,它使用JNI(本地调用程序)来进行本地调用COM库。

注意:

jacob只能在windows系统上运行。项目中服务器必须是windows server。

原因:

jacob需要借助Microsoft Office软件做pdf转换操作,因此需要在服务器上安装Microsoft Office 07/10/13。
一定要确保是64位的!!!一定要确保是64位的!!!一定要确保是64位的!!!

方法:

1.在pom中引入jar包
<dependency>
       <groupId>com.hynnet</groupId>
       <artifactId>jacob</artifactId>
       <version>1.18</version>
</dependency>
2.64位系统就用 x64的dll,32位系统就用x86的dll。将dll文件放入C:\Windows\System32

在这里插入图片描述

    /**
     * 将excel转成pdf
     * @param inFilePath
     * @param outFilePath
     * @throws Exception
     */
    public static void excelToPdf(String inFilePath, String outFilePath) throws Exception {
        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 = new Object[]{
                    inFilePath,
                    new Variant(false),
                    new Variant(false)
            };
            excel = Dispatch.invoke(excels, "Open", Dispatch.Method, obj, new int[9]).toDispatch();

            // 转换格式
            Object[] obj2 = new Object[]{
                    new Variant(0), // PDF格式=0
                    outFilePath,
                    new Variant(0)  //0=标准 (生成的PDF图片不会变模糊) ; 1=最小文件
            };
            Dispatch.invoke(excel, "ExportAsFixedFormat", Dispatch.Method, obj2, new int[1]);
        } catch (Exception es) {
            es.printStackTrace();
            throw es;
        } finally {
            if (excel != null) {
                Dispatch.call(excel, "Close", new Variant(false));
            }
            if (ax != null) {
                ax.invoke("Quit", new Variant[]{});
                ax = null;
            }
            ComThread.Release();
        }
    }
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值