JAVA通过COM接口操作PPT
一、 背景说明
在Eclipse环境下,开发JAVA代码操作PPT,支持对PPT模板的修改。包括修改文本标签、图表、表格。满足大多数软件生成PPT报告的要求,即先收工创建好模板,在程序中修改模板数据。
二、 开发环境搭建
下载jacob开源组件,解压后把jacob.jar添加到项目中。拷贝对应的dll文件到Path路径下。32位系统采用X86的dll, 64位系统采用X64的dll。
三、 实现合并PPT公共函数
import com.jacob.activeX.ActiveXComponent;
import com.jacob.com.Dispatch;
import com.jacob.com.Variant;
/**
* 通过jacob组件调用COM接口完成PPT文件的合并。合并后图表数据不丢失,用户可正常手工修改。
* 调用函数前将jacob.jar添加到项目中,同时将jcaob.dll拷贝到path路径下。
* @author Elon
*
*/
public class MergePPT
{
/**
* 合并多个PPT文件。要求输出文件和合并文件均已存在,不创建新文件。
* @param outPutPPTPath 合并后输出的文件路径。
* @param mergePPTPathList 依次追加合并的文件。
*/
public synchronized static void merge(String outPutPPTPath, List<String> mergePPTPathList)
{
// 启动 office PowerPoint程序
ActiveXComponent pptApp = new ActiveXComponent("PowerPoint.Application");
Dispatch.put(pptApp, "Visible", new Variant(true));
Dispatch presentations = pptApp.getProperty("Presentations").toDispatch();
// 打开输出文件
Dispatch outputPresentation = Dispatch.call(presentations, "Open", outPutPPTPath, false,
false, true).toDispatch();
// 循环添加合并文件
for (String mergeFile : mergePPTPathList)
{
Dispatch mergePresentation = Dispatch.call(presentations, "Open", mergeFile, false,
false, true).toDispatch();
Dispatch mergeSildes = Dispatch.get(mergePresentation, "Slides").toDispatch();
@SuppressWarnings("deprecation")
int mergePageNum = Dispatch.get(mergeSildes, "Count").toInt();
// 关闭合并文件
Dispatch.call(mergePresentation, "Close");
Dispatch outputSlides = Dispatch.call(outputPresentation, "Slides").toDispatch();
@SuppressWarnings("deprecation")
int outputPageNum = Dispatch.get(outputSlides, "Count").toInt();
// 追加待合并文件内容到输出文件末尾
Dispatch.call(outputSlides, "InsertFromFile", mergeFile, outputPageNum, 1, mergePageNum);
}
// 保存输出文件,关闭退出PowerPonit.
Dispatch.call(outputPresentation, "Save");
Dispatch.call(outputPresentation, "Close");
Dispatch.call(pptApp, "Quit");
}
}
四、 修改PPT中的文本、图表公共函数
/**
* 柱状图、饼图值类型
* @author Elon
*
*/
public class GraphValue implements Serializable
{
/**
*
*/
private static final long serialVersionUID = 4055958383254660746L;
/**
* 系列名称
*/
private String serialName = "";
/**
* 系列的值
*/
private ArrayList<String> valueList = new ArrayList<String>();
public String getSerialName()
{
return serialName;
}
public void setSerialName(String serialName)
{
this.serialName = serialName;
}
public ArrayList<String> getValueList()
{
return valueList;
}
public void setValueList(ArrayList<String> valueList)
{
this.valueList = valueList;
}
@Override
public String toString()
{
String str = "serialName:" + serialName + " valueList:";
for (String value : valueList)
{
str += value + ";";
}
return str;
}
}
/**
*
* 修改PPT图表、文本信息公共类定义。
*
* @author Elon
* @version 1.0, 2015年12月16日
*/
public class WritePPTUtil
{
/**
* PPT文件路径
*/
public String pptPath = "";
/**
* ppt对象
*/
private XMLSlideShow ppt = null;
/**
* 当前页签
*/
private XSLFSlide curSlide = null;
/**
* 打开ppt文件
* @param pptPath ppt文件路径
* @throws XmlException
* @throws OpenXML4JException
* @throws IOException 异常
*/
public void open(String pptPath) throws OpenXML4JException, IOException, XmlException
{
this.pptPath = pptPath;
XSLFSlideShow slideShow = new XSLFSlideShow(pptPath);
ppt = new XMLSlideShow(slideShow.getPackage());
}
/**
* 保存关闭文件
* @throws IOException
*/
public void close() throws IOException
{
FileOutputStream out = new FileOutputStream(pptPath + "_new.pptx");
ppt.write(out);
out.close();
}
/**
* 选中指定的PPT页签
* @param slideIndex 页签索引
* @return true:操作成功;false:操作失败
*/
public boolean selectSlide(int slideIndex)
{
if(ppt == null)
{
return false;
}
XSLFSlide[] slideArray = ppt.getSlides();
if(slideArray.length < slideIndex)
{
return false;
}
curSlide = slideArray[slideIndex];
return true;
}
/**
* 修改文本框内容
* @param shapeValue
* @param value
* @return
*/
public boolean modifyTextBox(String shapeValue, String value)
{
XSLFShape shape = getShape(shapeValue, ShapeType.TEXT_BOX_TYPE);
if (shape == null)
{
return false;
}
XSLFTextBox textBox = (XSLFTextBox)shape;
textBox.setText(value);
return true;
}
/**
*
* 修改图表内容。
*
* @param ShapeName 图表名称
* @param valueList
* @return
*/
public boolean modifyBargraph(String ShapeName, ArrayList<GraphValue> valueList)
{
XSLFShape shape = getShape("", ShapeType.GRAPHIC_TYPE);
XSLFGraphicFrame graphicShape = (XSLFGraphicFrame)shape;
XSLFSheet sheet = graphicShape.getSheet();
// 修改PPT图表内嵌的sheet的内容(待续)。
return true;
}
/**
* 获取PPT页签中指定的控件。
* @param shapeValue
* @param shapeType
* @return
*/
private XSLFShape getShape(String shapeValue, ShapeType shapeType)
{
if(curSlide == null)
{
return null;
}
String shapeName = "";
XSLFShape[] shapeArray = curSlide.getShapes();
for (int i = 0; i < shapeArray.length; ++i)
{
shapeName = shapeArray[i].getShapeName();
XSLFShape shape = shapeArray[i];
if ((shapeType == ShapeType.TEXT_BOX_TYPE)
&& (shape instanceof XSLFTextBox))
{
XSLFTextBox textBox = (XSLFTextBox)shape;
String value = textBox.getText();
if(value.equals(shapeValue))
{
return shapeArray[i];
}
}
else if ((shapeType == ShapeType.GRAPHIC_TYPE)
&& (shape instanceof XSLFGraphicFrame))
{
return shape;
}
}
return null;
}
}
五、 调用PPT合并函数测试代码
public class TestPPTMain
{
public static void main(String[] args) throws OpenXML4JException, IOException, XmlException
{
String outPutPPTPath = "D:\\TEMP\\template\\1.pptx";
List<String> mergePPTPathList = new ArrayList<String>();
mergePPTPathList.add("D:\\TEMP\\template\\2.pptx");
mergePPTPathList.add("D:\\TEMP\\template\\3.pptx");
MergePPT.merge(outPutPPTPath, mergePPTPathList);;
}
}
JAVA通过COM接口操作PPT的更多相关文章
- C++通过COM接口操作PPT
一. 背景 在VS环境下,开发C++代码操作PPT,支持对PPT模板的修改.包括修改文本标签.图表.表格.满足大多数软件生成PPT报告的要求,先手工创建好PPT模板,在程序中修改模板数据. 二. 开发 ...
- Java使用Unsafe接口操作数组Demo
public class unSafeArrayDemo { private static final sun.misc.Unsafe UNSAFE; private static final lon ...
- Java NIO Path接口和Files类配合操作文件
Java NIO Path接口和Files类配合操作文件 @author ixenos Path接口 1.Path表示的是一个目录名序列,其后还可以跟着一个文件名,路径中第一个部件是根部件时就是绝对路 ...
- java poi 操作ppt
java poi 操作ppt 可以参考: https://www.w3cschool.cn/apache_poi_ppt/apache_poi_ppt_installation.html http:/ ...
- java抽象类和接口区别
深入理解Java的接口和抽象类 对于面向对象编程来说,抽象是它的一大特征之一.在Java中,可以通过两种形式来体现OOP的抽象:接口和抽象类.这两者有太多相似的地方,又有太多不同的地方.很多人在初学的 ...
- 如何让Java和C++接口互相调用:JNI使用指南
如何让Java和C++接口互相调用:JNI使用指南 转自:http://cn.cocos2d-x.org/article/index?type=cocos2d-x&url=/doc/cocos ...
- Java中的队列:java.util.Queue接口
队列是一种特殊的线性表,它只允许在表的前端(front)进行删除操作,而在表的后端(rear)进行插入操作. Queue接口与List.Set同一级别,都是继承了Collection接口.Linked ...
- Java集合Map接口与Map.Entry学习
Java集合Map接口与Map.Entry学习 Map接口不是Collection接口的继承.Map接口用于维护键/值对(key/value pairs).该接口描述了从不重复的键到值的映射. (1) ...
- java的List接口的实现类 ArrayList,LinkedList,Vector 的区别
Java的List接口有3个实现类,分别是ArrayList.LinkedList.Vector,他们用于存放多个元素,维护元素的次序,而且允许元素重复. 3个具体实现类的区别如下: 1. Array ...
随机推荐
- 【技术干货】git常用命令
2.1 git init语法: git init在当前目录初始化git仓库,适用于尚未使用git管理的项目2.2 git clone语法: git clone <url>例如: git c ...
- 洛谷 P1486 [NOI2004]郁闷的出纳员【Treap】题解+AC代码
题目描述 OIER公司是一家大型专业化软件公司,有着数以万计的员工.作为一名出纳员,我的任务之一便是统计每位员工的工资.这本来是一份不错的工作,但是令人郁闷的是,我们的老板反复无常,经常调整员工的工资 ...
- springboot入门_data-jpa
今天学习了在springboot项目中访问数据库,做下笔记,以备后期查看. Spring Data JPA 是 Spring 基于 ORM 框架和JPA 规范 封装的一套应用框架,包含了增删改查等常用 ...
- 批量修改git仓库地址脚本
前言 公司的代码都存放在自己搭建的gitlab上面.之前由于老板升级gitlab.导致下面有个叫做"api"的groups无法访问.通过无所不能的谷歌才知道.在gitlab在某 ...
- Egret学习笔记 (Egret打飞机-4.添加主角飞机和实现飞行效果)
今天继续写点击了开始之后,添加一个飞机到场景中,然后这个飞机的尾巴还在冒火的那种感觉 先拆解一下步骤 1.首先完成飞机容器的图片加载 2.然后把容器添加到场景中 3.然后实现动画 -首先,我们新建一个 ...
- string (KMP+期望DP)
Time Limit: 1000 ms Memory Limit: 256 MB Description 给定一个由且仅由字符 'H' , 'T' 构成的字符串$S$. 给定一个最初为空的字符串 ...
- SIFT解析(一)建立高斯金字塔
SIFT(Scale-Invariant Feature Transform,尺度不变特征转换)在目标识别.图像配准领域具有广泛的应用,下面按照SIFT特征的算法流程对其进行简要介绍对SIFT特征做简 ...
- [php] in_array 判断问题(坑)
<?php $arr = array("Linux"); if (in_array(0, $arr)) { echo "match"; } ?> 执 ...
- C语言老司机学Python (二)
标准数据类型: 共6种:Number(数字),String(字符串),List(列表),Tuple(元组),Sets(集合),Dictionary(字典) 本次学习主要是和数据类型混个脸熟,知道每样东 ...
- Go基础之--操作Mysql(一)
关于标准库database/sql database/sql是golang的标准库之一,它提供了一系列接口方法,用于访问关系数据库.它并不会提供数据库特有的方法,那些特有的方法交给数据库驱动去实现. ...