C++操作Excel学习笔记(三)

这篇博客介绍了如何在C++中通过OLE方式读写Excel,主要涉及VS2008和Office2003环境下的操作。博主详细讲解了从新建MFC工程到编程实现合并单元格、设置单元格内容、格式和边框等步骤,帮助读者掌握Excel自动化操作。
摘要由CSDN通过智能技术生成

由于学习对Excel的操作是临时学的,有很多东西只是一知半解,但好歹是能运行了,相关内容可以参照前两篇学习笔记。

本文中使用的是OLE方式读写,环境是VS2008和Office2003。现在的编译器有自动完成功能,很容易找到相应的成员函数。查看函数原型有助于理解参数的意义,但仍是有些参数也搞不明白是什么作用,或者如何设置。Excel相关的预定义枚举类型,都是Xl开头,比如XlHAlign,是水平对齐,可以用XlHAlign::找到居中、靠右、靠左等应该设置的值。

步骤如下:

1.新建MFC工程,Project - Add Class - MFC Class From TypeLib,选择File,在Office安装目录下找到EXCEL.EXE,选择相应的接口(参考学习笔记二)。

 

2.VS2008会在工程中加入相应的头文件。打开头文件,把#import "D:\\Program Files\\Microsoft Office\\Office12\\EXCEL.EXE" no_namespace 一行改成:

#import "C:\\Program Files\\Common Files\\Microsoft Shared\\OFFICE11\\MSO.DLL" \
 rename("RGB", "MSORGB") \
 rename("DocumentProperties", "MSODocumentProperties") \
 rename("SearchPath","MsoSearchPath") \
 rename_namespace("Office")
using namespace Office;

#import "C:\\Program Files\\Common Files\\Microsoft Shared\\VBA\\VBA6\\VBE6EXT.OLB"

using namespace VBIDE;

#import "C:\\Program Files\\Microsoft Office\\Office11\\EXCEL.EXE" \
 rename("DialogBox", "ExcelDialogBox") \
 rename("RGB","ExcelRGB") \
 rename("CopyFile", "ExcelCopyFile") \
 rename("ReplaceText", "ExcelReplaceText") \
 no_auto_exclude

using namespace Excel;
#undef ExitWindows
#undef DialogBox
#undef RGB

注意“\”字符后面不能放空格

 

3.由于许多Word的对象与Excel对象的名字是相同的,因此两者同时使用是,必须使用名字空间将其区分。方法简单,比如自定义名字空间是_excel,则把接口头文件中

class C***

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值