java使用jacob调用com组件实现把excel的图表复制到word中
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了java使用jacob调用com组件实现把excel的图表复制到word中相关的知识,希望对你有一定的参考价值。
需求如上,求大神解决。。。
参考技术A 步骤一、先进入Excel表格,然后选中需要导入到Word文档中的区域,按下 Ctrl+C 复制;步骤二、打开Word,然后选择菜单栏的“编辑”中的“选择性粘贴”,在“形式”下面选中“Microsoft Office Excel 工作表 对象”然后确定;
此时,就已经把编辑好的Excel表格导入到Word中了,有的人这时肯定会说,这还不是和Word中表格没什么却别啊!确实,就这样用肉眼看,根本就看不错这个表格和Word中做的表格有什么不一样之处;
区别肯定是有的,不信你双击表格看看,会是什么效果,没错把,导入的表格和Excel中的表格一模一样,当然,这个表格也可以自由拖动它的长和宽,还可以运用Excel中的公式呢! 参考技术B 请问您解决这个问题了么,我现在碰见了这个问题。
Jacob用法收集
介绍
Jacob 是Java-COM Bridge的缩写,它在Java与微软的COM组件之间构建一座桥梁。使用Jacob自带的DLL动态链接库,并通过JNI的方式实现了在Java平台上对COM程序的调用。
安装和配置
Jacob是一个开源软件,它的官方站点是:http://danadler.com/jacob/
我的系统是64位,把jacob-1.18-M2-x64.dll复制到WindowsSystem32文件夹下,再 IDE中引用jacob.jar就可以使用了
读写Word简单示例
必须先在对应的路径下建立fileIn.doc,可以事先写入内容:
package king.word; import com.jacob.activeX.ActiveXComponent; import com.jacob.com.Dispatch; import com.jacob.com.Variant; public class Test { String strDir = "F:\桌面\Temp\"; String strInputDoc = strDir + "fileIn.doc"; String strOutputDoc = strDir + "fileOut.doc"; String strOldText = "oldText"; String strNewText = "It‘s very good to use java control Word"; boolean isVisible = true; boolean isSaveOnExit = true; public Test(){ ActiveXComponent oWord = new ActiveXComponent("Word.Application"); oWord.setProperty("Visible", new Variant(isVisible)); Dispatch oDocuments = oWord.getProperty("Documents").toDispatch(); Dispatch oDocument = Dispatch.call(oDocuments, "Open", strInputDoc).toDispatch(); Dispatch oSelection = oWord.getProperty("Selection").toDispatch(); Dispatch oFind = oWord.call(oSelection, "Find").toDispatch(); Dispatch.put(oFind, "Text", strOldText); Dispatch.call(oFind, "Execute"); Dispatch.put(oSelection, "Text", strNewText); Dispatch.call(oSelection, "MoveDown"); Dispatch.put(oSelection, "Text", "nSo we got the next line including BR.n"); Dispatch oFont = Dispatch.get(oSelection, "Font").toDispatch(); Dispatch.put(oFont, "Bold", "1"); Dispatch.put(oFont, "Italic", "1"); Dispatch.put(oFont, "Underline", "0"); Dispatch oAlign = Dispatch.get(oSelection, "ParagraphFormat").toDispatch(); Dispatch.put(oAlign, "Alignment", "3"); Dispatch oWordBasic = (Dispatch)Dispatch.call(oWord, "WordBasic").getDispatch(); Dispatch.call(oWordBasic, "FileSaveAs", strOutputDoc); Dispatch.call(oDocument, "Close", new Variant(isSaveOnExit)); oWord.invoke("Quit", new Variant(0)); } public static void main(String[] args){ new Test(); System.out.println("Done"); } }
jacob.jar的结构
jacob包括两个部分:
com.jacob.activeX: ActiveXComponent类
com.jacob.com: 其它类和元素
Jacob类
Jacob的结构很简单,包含以下几个类:
ActiveXComponent:封装了Dispatch对象,用于创建一个封装了COM组件对象的Java Object
Dispatch:用于指向封装后的MS数据结构。常用的方法有call,subcall,get,invoke…后面会介绍使用方法。
Variant:用于映射COM的Variant数据类型。提供Java和COM的数据交换。
ComException:异常类
Jacob方法
用于访问COM/DLL对象的方法,读取、修改COM/DLL对象的属性。
call:属于Dispatch类。用于访问COM/DLL对象的方法。方法进行了重载,方便不同场合调用。返回一个Variant类型的值。
callSub:使用方法和call一样,不过它不返回值。
get:读取COM对象的属性值,返回一个Variant类型值。
put:设置COM对象的属性值。
invoke:call的另一种用法,更复杂一些。
invokesub:subcall的另一种用法
getProperty:属于ActiveXComponent类,读取属性值,返回一个Variant类型值。
setProperty:属于ActiveXComponent类,设置属性值。
setProperty:属于ActiveXComponent类,设置属性值
文章转自:https://www.zybuluo.com/king/note/64983
以上是关于java使用jacob调用com组件实现把excel的图表复制到word中的主要内容,如果未能解决你的问题,请参考以下文章