准备工作
1.下载 jacob.jar
链接:https://pan.baidu.com/s/1TWIGyX9A3xQ6AG9Y3mVlVg
提取码:abcd
2.下载安装wps
WPS Office-支持多人在线编辑多种文档格式_WPS官方网站
3.添加 jar到项目和ddl文件放在jdk的jre/bin目录下,记得自己系统是64位还是32位的
ddl文件放jdk目录下
系统没有设置javahome的记得设置下
4.添加jacob.jar到项目中,我用的是idea springboot maven项目,执行maven打包到项目中
mvn install:install-file -Dfile=d:\jacob.jar -DgroupId=com.jacob -DartifactId=jacob -Dversion=1.19 -Dpackaging=jar
红色字体换成自己的
com.jacob
jacob
1.19
5.准备工作完成了我们上代码
import com.jacob.activeX.ActiveXComponent;
import com.jacob.com.Dispatch;
public class ToPdfTest {
private static final int wdFormatPDF = 17;
private static final int xlsTypePDF = 0;
private static final int ppSaveAsPDF = 32;
public static void main(String[] args) {
String path = "D:\\222.ppt"; // 自己在对应的位置放上需要转换的文件
String pdfPath = "D:\\test222.pdf";// pdfPath为生成PDF文件路径
//boolean bo = ToPdfTest.wordtoPDF(path, pdfPath); //word 转
//boolean bo = ToPdfTest.exceltoPDF(path, pdfPath); //excel转
boolean bo = ToPdfTest.ppttoPDF(path, pdfPath);
if (bo) {
System.out.println("恭喜您,转换完成!");
} else {
System.out.println("转换失败!");
}
}
// word转换为PDF
public static boolean wordtoPDF(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, "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 exceltoPDF(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", xlsTypePDF, pdfFile);
Dispatch.call(excel, "Close", false);
app.invoke("Quit");
return true;
} catch (Exception e) {
return false;
}
}
// PPT转换为PDF
public static boolean ppttoPDF(String inputFile, String pdfFile) {
try {
//ActiveXComponent app = new ActiveXComponent("KWPP.Application");//PowerPoint
ActiveXComponent app = new ActiveXComponent("PowerPoint.Application");
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) {
e.printStackTrace();
return false;
}
}
}
注意:原先我不知道wps也可以转,就用的office2016 但是excel转换你需要下载office相应插件SaveAsPDFandXPS,比较麻烦,所以我就用的office 代码我是网上搜的,不知道是谁的代码我忘了,这里说声不好意思