vc 操作excel 统计sheet数 获取表 获取表名

 CString sFile,sPath;
 _Application app;
 Workbooks books;
 _Workbook book;
 Worksheets sheets;
 _Worksheet sheet;
 int count=0; //工作表个数
 LPDISPATCH lpDisp;  //接口指针
    //获取主程序所在路径,存在sPath中
 GetModuleFileName(NULL,sPath.GetBufferSetLength (MAX_PATH+1),MAX_PATH);
 sPath.ReleaseBuffer ();
    int nPos;
 nPos=sPath.ReverseFind ('//');
 sPath=sPath.Left (nPos);
 sPath=ExcelMain.GetAppPath();
 sFile = sPath + "//基站信息表-1225.xls";    // 将被读取的Excel文件名
 
 COleVariant covOptional((long)DISP_E_PARAMNOTFOUND, VT_ERROR);
 
    if(CoInitialize(NULL)!=0) 
 { 
  AfxMessageBox("初始化COM支持库失败!"); 
  exit(1); 
 }
 
 //start Excel 2003 server 
 if (!app.CreateDispatch("Excel.Application",NULL)) 
 {
  AfxMessageBox("创建Excel服务失败!");
  exit(1);
 }
 
 CString sheetName;
 
 books=app.GetWorkbooks();

 lpDisp = books.Open(sFile,
        covOptional, covOptional, covOptional, covOptional,
        covOptional, covOptional, covOptional, covOptional,
        covOptional, covOptional, covOptional, covOptional);

 book.AttachDispatch( lpDisp );
 sheets=book.GetSheets();
 count=sheets.GetCount(); //获得工作表数量

 CString temp;
 temp.Format("%d",count);
 AfxMessageBox(temp);
 //循环所有表
 for(int i=1;i <=count;i++)
 {
  // AfxMessageBox("开始获取工作表!"); 
  //获取第i个工作表
  sheet=sheets.GetItem(COleVariant((short)i));
  sheetsNames[i] = sheet.GetName();//第i个工作表的表名  就是你要的表名 自己写个字符串数组或结构体来接收
  
 }
 app.Quit();

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值