首先先下载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的Excel | KET.Application |
WPS的演示文档(PPT) | KWPP.Application |
Word | Word.Application |
Excel | Excel.Application |
Powerpoint | Powerpoint.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;
}
}
}