JACOB语法

本文提供了一种新手友好的方法来理解如何在Java中使用JACOB库与ActiveX组件交互。文章详细介绍了创建ActiveXComponent实例、获取Dispatch对象以及执行ActiveX对象的操作,如读取属性、设置值和调用方法。同时,还提供了一个Excel操作的示例代码,帮助读者更好地掌握JACOB的用法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

如果你想写一个JAVA代码,其中需要调用JACOB提供的功能,而你还是新手,也许篇文章会大大降低你的花费时间。

我将一个关于JACOB的代码分成下面几个步骤:

1) ActiveXComponent ax = new ActiveXComponent("a1");//构建ActiveX组件实例

其中的a1的值和你需要调用的ActiveX控件有关

MS控件名

a1的值

InternetExplorer

InternetExplorer.Application

Excel

Excel.Application

Word

Word.Application

Powerpoint

Powerpoint.Application

vb/java Script

ScriptControl

windows media Player

WMPlayer.OCX

Outlook

Outlook.Application

Visio

Visio.Application

DAO

DAO.PrivateDBEngine.35

MultiFace

MultiFace.Face


2) Dispatch ds = ax.getObject(). toDispatch();//获取Dispatch对象,我们可以把每个Dispatch对象看成是对Activex控件的一个操作,这一步是获得该ActiveX控件的控制权。
(注: 浅析JACOB 中提到过Variant类,这里的ax.getObject()便是获得该对象,我们将其转化为任何对象(类型))

3) Dispatch ds1 = Dispatch.get(ds, "a2").toDispatch(); //获取该ActiveX对象数据结构中的a2属性

4) Dispatch d2 = Dispatch.invoke(ds1, "a3", a4, a5, a6).toDispatch(); //功能调用,对ActiveX对象ds1的a3属性执行a4(Dispatch.Put\Dispatch.Get等)操作,执行后a3的值为a5,a6为错误参数码常定义为new int[1],
(注:call、get和put方法都是通过该方法实现的)

5) Dispatch ds2 = Dispatch.put(ds, "a7","a8").toDispatch();//将ActiveX对象ds的属性a4的值设置为a5,该方法返回类型同get一样

6) Dispatch ds3 = Dispatch.call(ds1, "a9", a10);//该方法和get方法非常类似,他是把a9属性赋值给a10

Ok其他的方法我觉得很容易理解,这里就不再做描述了。

下面是一个关于excel的代码,也许对您的进一步自学,会有好处
import com.jacob.activeX.ActiveXComponent;
import com.jacob.com.ComThread;
import com.jacob.com.Dispatch;
import com.jacob.com.Variant;

public class ExcelDispatchTest {

public static void main(String[] args) {
ComThread.InitSTA();

ActiveXComponent xl
= new ActiveXComponent("Excel.Application");
try {
System.out.println(
"version=" + xl.getProperty("Version"));
System.out.println(
"version=" + Dispatch.get(xl, "Version"));
Dispatch.put(xl,
"Visible", new Variant(true));
Dispatch workbooks
= xl.getProperty("Workbooks").toDispatch();
Dispatch workbook
= Dispatch.get(workbooks, "Add").toDispatch();
Dispatch sheet
= Dispatch.get(workbook, "ActiveSheet").toDispatch();
Dispatch a1
= Dispatch.invoke(sheet, "Range", Dispatch.Get,
new Object[] { "A1" }, new int[1]).toDispatch();
Dispatch a2
= Dispatch.invoke(sheet, "Range", Dispatch.Get,
new Object[] { "A2" }, new int[1]).toDispatch();
Dispatch.put(a1,
"Value", "123.456");
Dispatch.put(a2,
"Formula", "=A1*2");
System.out.println(
"a1 from excel:" + Dispatch.get(a1, "Value"));
System.out.println(
"a2 from excel:" + Dispatch.get(a2, "Value"));
Variant f
= new Variant(false);
Dispatch.call(workbook,
"Close", f);
}
catch (Exception e) {
e.printStackTrace();
}
finally {
xl.invoke(
"Quit", new Variant[] {});
ComThread.Release();
}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值