CWorkBooks、CWorkBook、CWorkSheets、CWorkSheet、CRange简介以及导入MFC工程

操作Excel对我们来说是常有的事,有时经常需要从Excel中导入数据,或者把报表保存到Excel中去;但是对于Excel编程来说肯定少不了要遇到六个最基本的类(CApplication、CWorkBook、CWorkBooks、CWorkSheet、CWorkSheets、CRange),下面我们来一一介绍一下这五个类,相信你掌握了这五个类后你对于Excel编程也会熟练很多。话不多说,我们一一来认识他们吧!!

1、CApplication类
CApplication类,看这名字相信很多人对他都会有一个大体的认识,对,他就是Excel应用程序类;CApplication类的主要职责就是管理我们打开的这整个Excel应用。

2、CWorkBooks类

CWorkBooks类,这个统管所有的工作簿,换句话说就是管理我们所有打开的xls文件。像我们打开了多少个xls文件,所有xls文件在程序中的位置等等这些信息。

3、CWorkBook类

CWorkBook类,这个类看起来和CWorkBooks类很像,也就是少了一个S而已。其实CWorkBook类和CWorkBooks我觉得还是有点像的,因为CWorkBooks类就是CWorkBook类的集合。CWorkBook类管理的是单个工作表,而CWorkBooks管理的是工作表集合。他们之间可以算是一种从属关系。

4、CWorkSheets类

CWorkSheets类,他的功能和CWorkBooks类有点类似,统管当前工作簿中的所有工作表。

5、CWorkSheet类

CWorkSheet类,他扮演的角色和CWorkBook很相似,只不过所属的层面不一样,但是,在编程中我们碰到他的情况可能比前面几个类都要多。

6、CRange类

CRange类, 我把这个类叫做区域类,也就是我们xls文件中可以编辑的区域,他可大可小,大可以包含当前工作表的所有单元格,小的时候可以只包含一个单元格;我们对Excel文件的操作大部分都在这个类里面,例如读取Excel数据,修改数据、写入数据、更改单元格格式等等,都要和这个类打交道。

 

导入MFC工程:

1. 建立MFC工程

2. 操作Excel文件初始化: 

  • project->add class->MFC class from typelib (项目->添加类->Typelib中的MFC类)导入Excel.exe,一般都在C:/Program Files/Microsoft Office/Office15路径下(即选择你的office安装路径下的excel.exe加入)
  • 选中以下几项_Application,_WorkSheet,_WorkBook,WorkSheets,WorkBooks,Range,然后导入;
  • 导入后自动在工程中添加CApplication,CWorkSheet,CWorkBook,CWorkSheets,CWorkBooks,CRange这些类;

然后需要把这些类的头文件中的第一句话 #import ".......EXCEL.EXE" nonamespace 删除;并添加#include <afxdisp.h>

引入之后如果编译遇到错误,Not enough actual parameters for macro ''DialogBoxW''. 让人头疼!

解决方法是在CRange类中:

 

VARIANT DialogBox()
{
	VARIANT result;
	InvokeHelper(0xf5, DISPATCH_METHOD, VT_VARIANT,(void*)&result, NULL);
	return result;
} 
DialogBox()前面添加下划线变成_DialogBox(),解决了!

 

 

 

 

转自:https://blog.csdn.net/u010521560/article/details/76296975

           https://blog.csdn.net/u014023993/article/details/25042199

  • 1
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值