1。下在Java-COM连接桥JACOB(http://danadler.com/jacob/),需要jacob.jar和jacob.dll两个文件就可以了。并把jacob.dll所在目录设到PATH。
2。调用程序(Exam_2.java)如下:
import java.io.File;
import com.jacob.com.*;
import com.jacob.activeX.*;public class Exam_2 {
 
 public static void main(String[] args) {
    
  ActiveXComponent app = new ActiveXComponent("Word.Application");//启动word
  String inFile = "H:\\Majix-1_2_2_full\\sample\\my.doc";//要转换的word文件
  String tpFile = "H:\\Majix-1_2_2_full\\sample\\my.htm";//临时文件
  String otFile = "H:\\Majix-1_2_2_full\\sample\\my.xml";//目标文件
  boolean flag = false;
  try {
   app.setProperty("Visible", new Variant(false));//设置word不可见
   Object docs = app.getProperty("Documents").toDispatch();
   Object doc = Dispatch.invoke(docs,"Open", Dispatch.Method, new Object[]{inFile,new Variant(false), new Variant(true)}, new int[1]).toDispatch();//打开word文件
   Dispatch.invoke(doc,"SaveAs", Dispatch.Method, new Object[]{tpFile,new Variant(8)}, new int[1]);//作为html格式保存到临时文件
   Variant f = new Variant(false);
   Dispatch.call(doc, "Close", f);
   flag = true;
  } catch (Exception e) {
   e.printStackTrace();
  } finally {
   app.invoke("Quit", new Variant[] {});
  }
  
  if ( flag ) {
   app = new ActiveXComponent("Excel.Application");//启动excel
   try {
    app.setProperty("Visible", new Variant(false));//设置excel不可见
    Object workbooks = app.getProperty("Workbooks").toDispatch();
    Object workbook = Dispatch.invoke(workbooks,"Open",Dispatch.Method,new Object[]{tpFile,new Variant(false), new Variant(true)}, new int[1]).toDispatch();//打开临时文件
    Dispatch.invoke(workbook,"SaveAs", Dispatch.Method, new Object[]{otFile,new Variant(46)}, new int[1]);//以xml格式保存到目标文件
    Variant f = new Variant(false);
    Dispatch.call(workbook, "Close", f);
   } catch (Exception e) {
    e.printStackTrace();
   } finally {
    app.invoke("Quit", new Variant[] {});
    try {
     File file = new File(tpFile);
     file.delete();
    } catch (Exception e) {
    }
   }
  }
 }
}
3。编译执行(确保jacob.dll在PATH中)
H:\mytest>javac -classpath jacob.jar Exam_2.java
H:\mytest>java -cp jacob.jar;. Exam_2将 m$ word 转换为 xml 的java程序问题的通用实现的通用方法,其他COM对象也可以一样的解决。

解决方案 »

  1.   

    用COM组件的办法是可以完成此功能,但是运行久了经常出问题:(http://www.javayou.com
      

  2.   

    to  jein(幽灵)
    这段代码我有。
    我就是用这个把word存为html格式的
    但是把excel存为html的时候,就会出现乱码,而且保存目录也没有出现.files的目录。
      

  3.   

    word和excel可能超做的时候需要有些东西要改下,如果照着上面的直接改肯定不行啊,excel的文件不能用word打开,但是原理肯定是一样的,具体你再试试看,我也没有做过这个。如果实在不行的话,把excel的数据写到数据库里面去,再从数据库里面显示到html里面(不过这个方法太死了)。
      

  4.   

    代码肯定要改的,我已经改过了。如下:
    app = new ActiveXComponent("Excel.Application");//启动excel
    app.setProperty("Visible", new Variant(false));//设置excel不可见
    Object workbooks = app.getProperty("Workbooks").toDispatch();
    Object workbook = Dispatch.invoke(workbooks,"Open",Dispatch.Method,new Object[]{tpFile,new Variant(false), new Variant(true)}, new int[1]).toDispatch();//打开目标文件
    Dispatch.invoke(workbook,"SaveAs", Dispatch.Method, new Object[]{otFile,new Variant(8)}, new int[1]);//以xml格式保存到目标文件
    Variant f = new Variant(false);
    Dispatch.call(workbook, "Close", f);保存是可以,但是原来的格式全没了。
    不像EXCEL自带的保存为html页的效果。现在主要是不清楚,dispatch.invoke()所用到的参数什么用?