武汉北大青鸟鲁广校区java技术
如果你想写一个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/javaScript | ScriptControl |
windowsmediaPlayer | 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的代码,也许对您的进一步自学,会有好处
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(); } } |
- 大学生学互联网技术好不好?武汉北大青鸟
- 武汉比较好的新媒体互联网运营培训学校学费情况
- 武汉全媒体短视频运营哪个培训机构好?全媒体运营专业
- 武汉新媒体运营培训班靠谱推荐?北大青鸟助你成就新媒体之路!
- 武汉北大青鸟2024年寒假招生火热启动!
- 北大青鸟:北大青鸟招生简章【2024新版】
- 武汉网络安全工程师学什么?计算机网络安全培训
- 北大青鸟:2024年计算机技术和互联网行业依旧繁荣
- 武汉计算机职业培训学校哪家好?
- 在武汉学前端开发后的就业前景如何?
看过该Java开发的还看过
本文标题:#JACOB的语法#,宏鹏发布于北大青鸟鲁广校区。武汉北大青鸟鲁广校区java技术 如果你想写一个JAVA代码,其中需要调用JACOB提供的功能,而你还是新手,也许篇文章会大大降低你的花费时间。 我将一个关于JACOB的代码分成下面几个步