Java利用Jacob实现excel,ppt,word转pdf

1 篇文章 0 订阅

首先先下载jar包

这个仅在window下有用,它利用自带office或者是WPS实现的
Jacob 官网https://sourceforge.net/projects/jacob-project/
点击这个打开后等待5秒钟自动下载https://sourceforge.net/projects/jacob-project/files/latest/download

压缩后
需要将jacob*.dll文件复制到jdk的bin目录下,类似:D:\Program Files\Java\jdk1.8.0_144\bin
我的只放在了jdk下就可以了,也有人说jre下面也要放,可以自己试试
下面上代码
控件说明:这个方法实际就是调用本地的 WPS 或者office 来实现转换的
只需要将下面方法里开头的这句话,根据下面的 name 改了就可以
ActiveXComponent app= new ActiveXComponent(“name”);
其中的 name 的值和你需要调用的ActiveX控件有关,看你想用WPS还是office了,我还是推荐WPS,office激活还挺麻烦的还有版本问题

MS控件名name值
WPS文字KWPS.Aplication
WPS的ExcelKET.Application
WPS的演示文档(PPT)KWPP.Application
WordWord.Application
ExcelExcel.Application
PowerpointPowerpoint.Application
public class PDFUtil {

private static final int ppSaveAsPDF = 32;

	public static void main(String[] args) {
		//path:原文档路径,也可以为一个网络地址
		//pdfPath为生成的pdf文件路径
		String path = "F:/test.doc";
		String pdfPath = "F:/test.pdf";
		boolean bo = PDFUtil.word2PDF(path,pdfPath);
		if(bo){
			System.out.println("转换完成!");
		}else{
			System.out.println("转换失败!");				
			 }
	}
	// word转换为pdf
	public static boolean word2PDF(String inputFile, String pdfFile) {
		try {
			// 打开word应用程序
			ActiveXComponent app = new ActiveXComponent("Word.Application");
			// 设置word不可见
			app.setProperty("Visible", false);
			// 获得word中所有打开的文档,返回Documents对象
			Dispatch docs = app.getProperty("Documents").toDispatch();
			// 调用Documents对象中Open方法打开文档,并返回打开的文档对象Document
			Dispatch doc = Dispatch.call(docs, "Open", inputFile, false, true)
					.toDispatch();
			// 调用Document对象的SaveAs方法,将文档保存为pdf格式
			/*
			 * Dispatch.call(doc, "SaveAs", pdfFile, wdFormatPDF
			 * //word保存为pdf格式宏,值为17 );
			 */
			Dispatch.call(doc, "ExportAsFixedFormat", pdfFile, wdFormatPDF);// word保存为pdf格式宏,值为17
			// 关闭文档
			Dispatch.call(doc, "Close", false);
			// 关闭word应用程序
			app.invoke("Quit", 0);
			return true;
		} catch (Exception e) {
			return false;
		}
	}
	// excel转换为pdf
	public static boolean excel2PDF(String inputFile, String pdfFile) {
		try {
			ActiveXComponent app = new ActiveXComponent("Excel.Application");
			app.setProperty("Visible", false);
			Dispatch excels = app.getProperty("Workbooks").toDispatch();
			Dispatch excel = Dispatch.call(excels, "Open", inputFile, false,
					true).toDispatch();
			Dispatch.call(excel, "ExportAsFixedFormat", xlTypePDF, pdfFile);
			Dispatch.call(excel, "Close", false);
			app.invoke("Quit");
			return true;
		} catch (Exception e) {
			return false;
		}
	}
	// ppt转换为pdf
	public static boolean ppt2PDF(String inputFile, String pdfFile) {
		try {
			ActiveXComponent app = new ActiveXComponent(
					"PowerPoint.Application");
			// app.setProperty("Visible", msofalse);
			Dispatch ppts = app.getProperty("Presentations").toDispatch();
 
			Dispatch ppt = Dispatch.call(ppts, "Open", inputFile, true,// ReadOnly
					true,// Untitled指定文件是否有标题
					false// WithWindow指定文件是否可见
					).toDispatch();
 
			Dispatch.call(ppt, "SaveAs", pdfFile, ppSaveAsPDF);
 
			Dispatch.call(ppt, "Close");
 
			app.invoke("Quit");
			return true;
		} catch (Exception e) {
			return false;
		}
	}
	}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值