欢迎访问北大青鸟鲁广校区~

  1. 加入收藏
  2. 设为主页
  3. 学校简介
北大青鸟鲁广校区

17740513250

三分钟了解北大青鸟

×
  • 数据加载中...

JACOB的语法

责任编辑:宏鹏来源:武汉北大青鸟鲁广校区发布时间:2015-10-09 10:03:02
导读:武汉北大青鸟鲁广校区java技术 如果你想写一个JAVA代码,其中需要调用JACOB提供的功能,而你还是新手,也许篇文章会大大降低你的花费时间。 我将一个关于JACOB的代码分成下面几个步

武汉北大青鸟鲁广校区java技术  

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

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

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

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

MS控件名a1的值
InternetExplorerInternetExplorer.Application
ExcelExcel.Application
WordWord.Application
PowerpointPowerpoint.Application
vb/javaScriptScriptControl
windowsmediaPlayerWMPlayer.OCX
OutlookOutlook.Application
VisioVisio.Application
DAODAO.PrivateDBEngine.35
MultiFaceMultiFace.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的代码,也许对您的进一步自学,会有好处

importcom.jacob.activeX.ActiveXComponent;

importcom.jacob.com.ComThread;

importcom.jacob.com.Dispatch;

importcom.jacob.com.Variant;

publicclassExcelDispatchTest{

publicstaticvoidmain(String[]args){

ComThread.InitSTA();

ActiveXComponentxl=newActiveXComponent("Excel.Application");

try{

System.out.println("version="+xl.getProperty("Version"));

System.out.println("version="+Dispatch.get(xl,"Version"));

Dispatch.put(xl,"Visible",newVariant(true));

Dispatchworkbooks=xl.getProperty("Workbooks").toDispatch();

Dispatchworkbook=Dispatch.get(workbooks,"Add").toDispatch();

Dispatchsheet=Dispatch.get(workbook,"ActiveSheet").toDispatch();

Dispatcha1=Dispatch.invoke(sheet,"Range",Dispatch.Get,

newObject[]{"A1"},newint[1]).toDispatch();

Dispatcha2=Dispatch.invoke(sheet,"Range",Dispatch.Get,

newObject[]{"A2"},newint[1]).toDispatch();

Dispatch.put(a1,"Value","123.456");

Dispatch.put(a2,"Formula","=A1*2");

System.out.println("a1fromexcel:"+Dispatch.get(a1,"Value"));

System.out.println("a2fromexcel:"+Dispatch.get(a2,"Value"));

Variantf=newVariant(false);

Dispatch.call(workbook,"Close",f);

}catch(Exceptione){

e.printStackTrace();

}finally{

xl.invoke("Quit",newVariant[]{});

ComThread.Release();

}

}

本文标题:#JACOB的语法#,宏鹏发布于北大青鸟鲁广校区。武汉北大青鸟鲁广校区java技术 如果你想写一个JAVA代码,其中需要调用JACOB提供的功能,而你还是新手,也许篇文章会大大降低你的花费时间。 我将一个关于JACOB的代码分成下面几个步

专业老师指导

专业老师指导

赵老师

从事IT教育培训十年有余,致力于帮助广大学子找到适合自己的专业。

培训咨询客服

培训咨询客服

陈老师

IT培训专业客服,用自己的真诚解决了无数学子的困惑。

本文地址:http://www.027hpedu.com/tag/50.html
文章标题:JACOB的语法

大家都在看的大家都在看的Java开发

热门课程

更多>>
  • 数据加载中...
7天免费试学

7天课程免费试学

实战学习干货限时领取

行业解读+大咖授课+项目实操
10年以上业内强师集结,手把手带你蜕变精英!

点我咨询
×
在线咨询更多问题

如您有任何疑问
在线咨询随时为您解答或拨打咨询热线:13125006136

×
  • 姓 名*
  • 手 机*
  • QQ号/微信号
  • 所报学科 *
  • 其他备注
  • 验证码 获取验证码 *
  • 温馨提示:请保持手机畅通,咨询老师将为您提供专属的一对一报名服务。