zoukankan      html  css  js  c++  java
  • java jacob 的一些小总结

    当前时间 2021年08月17日,Jacob 项目早已迁移到了 GitHub 上,地址如下 ↓

    https://github.com/freemansoft/jacob-project

     

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

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

    //一
    ActiveXComponent ax = new ActiveXComponent("a1");
    //二 Dispatch ds = ax.getObject().toDispatch();
    //三 Dispatch ds1 = Dispatch.get(ds, "a2").toDispatch();
    //四 Dispatch d2 = Dispatch.invoke(ds1, "a3", a4, a5, a6).toDispatch();
    //五 Dispatch ds2 = Dispatch.put(ds, "a7", "a8").toDispatch();
    //六 Dispatch ds3 = Dispatch.call(ds1, "a9", a10);

    ------下面对以上步骤做具体介绍-------

    //一
    ActiveXComponent ax = new ActiveXComponent("a1");
    //构建ActiveX组件实例
    //其中的 a1 的值和你需要调用的 ActiveX 控件有关,具体参照下面的表格,选用自己合适的值。
    //比如如果要操作 Excel 的话,则 → ActiveXComponent ax = new ActiveXComponent("Excel.Application"); 

    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

     

       

    //二
    Dispatch ds = ax.getObject().toDispatch();
    //获取Dispatch对象,我们可以把每个 Dispatch 对象看成是对 Activex 控件的一个操作,这一步是获得该 ActiveX 控件的控制权。
    //注:浅析 JACOB 中提到过 Variant 类,这里的 ax.getObject() 便是获得该对象,我们可以将其转化为任何对象(类型)。
    //三
    Dispatch ds1 = Dispatch.get(ds, "a2").toDispatch();
    //获取该 ActiveX 对象数据结构中的 a2 属性   
    //四
    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方法都是通过该方法实现的)。 
    //五
    Dispatch ds2 = Dispatch.put(ds, "a7", "a8").toDispatch();
    //将 ActiveX 对象 ds 的属性 a4 的值设置为 a5,该方法返回类型同 get 一样
    //六
    Dispatch ds3 = Dispatch.call(ds1, "a9", a10);
    //该方法和 get 方法非常类似,他是把a9属性赋值给a10

     

    下面是一个官方的 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();     }   } }

      

     

     

     

     

     

     

     

  • 相关阅读:
    QR code
    复制一个带random指针的链表
    运行时const
    海量处理 bitmap及区段划分
    socket编程随记
    BLS签名
    load balancing
    Bloom Filter (2)
    #include 的花样
    拓扑排序、Dijkstra、Prim/Kruskal、全部最短路径/传递闭包
  • 原文地址:https://www.cnblogs.com/sungong1987/p/15151243.html
Copyright © 2011-2022 走看看