大家好啊! 我是寻觅
最近天气变化多,大家要多注意身体啊~~~
好了进如正题,最近在帮个朋友做java调用office的东东,花了些时间,终于搞定了由于问题多多,现在把过程和大家分享:
首先,大家先要了解一下jacob ,官方的解释是Java COM Bridge,即java和com组件间的桥梁(进一步了解com/dcom: http://docs.huihoo.com/com/)com一般表现为dll或exe等二进制文件,像我们呆会会用到的jacob.dll文件这里说说为什么我们用java去操纵office(如:word)要使用com,而不直接使用java去做?
首先,我们清楚office是建立在windows平台之上的,本身是一个软件,除了他自己提供的宏似乎没有什么能对他进行直接的操作;在windows平台上为了解决像这样的不同应用软件,通信缺乏通用api问题,推出了com的解决方案;
我们使用dll中的一组或多组相关的函数存取组件数据,总的合称为接口具体到每个细节的实现称为方法;如果我们要调用接口里的方法,唯一的途径就是调用指向接口的指针;
所以总的来说使用就是dll完成api的转换;
如果你听不懂,则称为废话(不懂没关系,会用就好,用久自然懂了);
开玩笑,呵呵
好了com讲完,我们开始我们的主要内容吧!
大家先下载这里
jacob_1.9.zip
里面的jacob.jar是我们要用的包
jacob.dll就是我前面说的com组件
把包里的jacob.dll放到c:/windows/system32下
讲解麻烦,画个图大家看 好
值得注意的是,不同的版本的系统使用不同的dll文件
所以如果你编译成功,但运行失败一般是dll文件问题
遇到这种情况,可以到
http://downloads.sourceforge.net/jacob-project/jacob_1.9.zip?modtime=1109437002&big_mirror=0
下载其他的版本的 dll 文件。
先给大家个word的测试代码(经过更改该代码在我的机器上运行正常)
以后有会找时间,推出其他的office代码
import com.jacob.activeX.ActiveXComponent;
import com.jacob.com.ComException;
import com.jacob.com.Dispatch;
import com.jacob.com.Variant;
public class WordDocumentProperties {
// 声明一个word对象
private ActiveXComponent objWord;
// 声明四个word组件
private Dispatch custDocprops;
private Dispatch builtInDocProps;
private Dispatch document;
private Dispatch wordObject;
public WordDocumentProperties() {
}
/** */ /**
* 打开word文挡
*/
public void open(String filename) {
// 创建一个word对象
objWord = new ActiveXComponent( " Word.Application " );
// 为wordobject组件附值
wordObject = (Dispatch)(objWord.getObject()); // 改了这里
// 生成一个只读方式的word文挡组件
Dispatch.put(wordObject, " Visible " , new Variant( false ));
// 获取文挡属性
Dispatch documents = objWord.getProperty( " Documents " ).toDispatch();
// 打开激活文挡
document = Dispatch.call(documents, " Open " , filename).toDispatch();
}
public void selectCustomDocumentProperitiesMode() {
custDocprops = Dispatch.get(document, " CustomDocumentProperties " )
.toDispatch();
}
public void selectBuiltinPropertiesMode() {
builtInDocProps = Dispatch.get(document, " BuiltInDocumentProperties " )
.toDispatch();
}
/** */ /**
* 关闭文挡
*/
public void close() {
Dispatch.call(document, " Close " );
}
public String getCustomProperty(String cusPropName) {
try {
cusPropName = Dispatch.call((Dispatch) custDocprops, " Item " ,
cusPropName).toString();
} catch (ComException e) {
cusPropName = null ;
}
return cusPropName;
}
public String getBuiltInProperty(String builtInPropName) {
try {
builtInPropName = Dispatch.call((Dispatch) builtInDocProps, " Item " ,
builtInPropName).toString();
} catch (ComException e) {
builtInPropName = null ;
}
return builtInPropName;
}
public static void main(String[] args) {
try {
WordDocumentProperties jacTest = new WordDocumentProperties();
jacTest.open( " s.doc " );
jacTest.selectCustomDocumentProperitiesMode();
jacTest.selectBuiltinPropertiesMode();
String custValue = jacTest.getCustomProperty( " Information Source " );
String builtInValue = jacTest.getBuiltInProperty( " Author " );
jacTest.close();
System.out.println( " Document Val One: " + custValue);
System.out.println( " Document Author: " + builtInValue);
} catch (Exception e) {
System.out.println(e);
}
}
}