目的:通过vc++读取和写入excel
环境:vs2012 office2010
1.创建一个新的工程,选择mfc application,选择dialog,在advanced features选择automation(这一项我不确定有没有必要,查资料说要选上,我就选上了)
2.创建完工程后,在dialog对话框上右击,选择class wizard(或是ctrl+shift+x)
3.在add class下拉框内选择add class from typelib
4.在add class from下面选择file,然后你的office安装目录下的EXCEL.EXE(我的目录是C:\Program Files (x86)\Microsoft Office\Office14\EXCEL.EXE)
5.在下面添加6个类到我们的工程,(_Application, Worksheets, _Worksheet, Workbooks, _Workbook, Range)注意有的有下划线,别添加错了
6.这个时候如果直接编译程序会提示错误,大体错误的信息如下
大体错误的信息如下
[plain] view plain copy
Error 1 error C1083: Cannot open compiler generated file: ‘d:\code\vc\exceltojson\exceltojson\debug\excel.tlh’: Permission denied d:\code\vc\exceltojson\exceltojson\capplication.h 3 1 EXCELToJSON
[plain] view plain copy
2 IntelliSense: declaration modifiers are incompatible with previous declaration d:\code\VC\EXCELToJSON\EXCELToJSON\Debug\excel.tlh 573 19 EXCELToJSON
出现很多错误,几乎都与excel.tlh这个文件相关。
解决方法就是把导入的6个类对应的头文件最开始的一句话
[cpp] view plain copy
import “C:\Program Files (x86)\Microsoft Office\Office14\EXCEL.EXE” no_namespace
注释掉,也就是删掉。具体原因不明,估计是这个已经更新不用了,但是模版里面没有改。所以引用了没有的东西出的错
7.做完上面的操作