基于jcom,java写数据到excel方式二(IDispatch)

 

package sample1;

import java.io.File;

import jp.ne.so_net.ga2.no_ji.jcom.IDispatch;
import jp.ne.so_net.ga2.no_ji.jcom.JComException;
import jp.ne.so_net.ga2.no_ji.jcom.ReleaseManager;

public class JcomExcelSample2 {

 private static ReleaseManager rm = null;
 private static IDispatch xlsApp = null;
 private static IDispatch excel = null;
 private static IDispatch workbook = null;// 工作薄
 private static IDispatch sheets = null;// 所有工作表(是一个数组形式)
 private static IDispatch sheet = null;// 单个工作表
 private static IDispatch currentSheet  = null;// 当前活动的工作表

 
 public static void main(String[] args) {

  rm = new ReleaseManager();// 查找JCOM能够操作的组件
  try {
   xlsApp = new IDispatch(rm, "Excel.Application");
   excel = (IDispatch) xlsApp.get("Workbooks");// 得到工作薄
   xlsApp.put("Visible", new java.lang.Boolean(false)); // 设置当前对象是否可见
   
   File f = new File("D://testExcel.xls" );
   if (f.exists()) {}//判断文件是否存在
   
   workbook = (IDispatch) excel.method("open",
     new Object[] {"D://testExcel.xls" }); // 打开工作薄

   sheets = (IDispatch) workbook.get("Sheets");
   int sheetsCount = Integer.parseInt(sheets.get("Count").toString());// 得到工作表的数量
   for (int sheetInx = 1; sheetInx <= sheetsCount; sheetInx++) { // 得到各个工作表的名称
     sheet = (IDispatch) sheets.get("item",//按照工作表索引得到工作表
      new Object[] { new Integer(sheetInx) });
    String sheetName = sheet.get("name").toString();
    sheet.put("name", "Nsheet"+sheetInx);//修改当前工作表的名称

   }
   currentSheet = (IDispatch) xlsApp.get("ActiveSheet"); //得到当前获得的工作表
   currentSheet.put("name", "new sheet");
   
  } catch (JComException e) {
   e.printStackTrace();
  }
 }

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值