MFC 读取EXCEL表格 VS2008
2015-05-29 13:56
274 查看
我们的上位机需要一个配置文件INI,但是数据项有点多看起来很乱,而EXCEL在保存一些配置数据的时候有独特的优势,所以就在EXCEL里边配置,利用上位机读EXCEL。
一、建立工程:
a. project->add class->MFC class from typelib (项目->添加类->Typelib中的MFC类)导入Excel.exe,一般都在C:/Program Files/Microsoft Office/Office12路径下(即选择你的office安装路径下的excel.exe加入)
b. 选中以下几项_Application,_WorkSheet,_WorkBook,WorkSheets,WorkBooks,Range,然后导入;
c. 导入后自动在工程中添加CApplication,CWorkSheet,CWorkBook,CWorkSheets,CWorkBooks,CRange这些类;
然后需要把这些类的头文件中的第一句话 #import ".......EXCEL.EXE" nonamespace 删除;
引入之后如果编译遇到错误,Not enough actual parameters for macro 'DialogBoxW'. 让人头疼!
解决方法是在CRange类中,VARIANT DialogBox()前面添加下划线变成VARIANT _DialogBox(),解决了!
二、添加头文件
三、添加操作代码
有读取单元格的函数基本也就差不多了,有想法就去做
一、建立工程:
a. project->add class->MFC class from typelib (项目->添加类->Typelib中的MFC类)导入Excel.exe,一般都在C:/Program Files/Microsoft Office/Office12路径下(即选择你的office安装路径下的excel.exe加入)
b. 选中以下几项_Application,_WorkSheet,_WorkBook,WorkSheets,WorkBooks,Range,然后导入;
c. 导入后自动在工程中添加CApplication,CWorkSheet,CWorkBook,CWorkSheets,CWorkBooks,CRange这些类;
然后需要把这些类的头文件中的第一句话 #import ".......EXCEL.EXE" nonamespace 删除;
引入之后如果编译遇到错误,Not enough actual parameters for macro 'DialogBoxW'. 让人头疼!
解决方法是在CRange类中,VARIANT DialogBox()前面添加下划线变成VARIANT _DialogBox(),解决了!
二、添加头文件
#include "CApplication.h" #include "CRange.h" #include "CWorkbook.h" #include "CWorkbooks.h" #include "CWorksheet.h" #include "CWorksheets.h"
三、添加操作代码
void CMonitorDlg::OnBnClickedButton1() { // TODO: 在此添加控件通知处理程序代码 CApplication app; CWorkbooks books; CWorkbook book; CWorksheets sheets; CWorksheet sheet; CRange range; CRange iCell; LPDISPATCH lpDisp; COleVariant vResult; COleVariant covOptional((long)DISP_E_PARAMNOTFOUND, VT_ERROR); if(!app.CreateDispatch("Excel.Application")) { AfxMessageBox("无法启动Excel服务器!"); return; } app.put_Visible(TRUE); app.put_UserControl(FALSE); books.AttachDispatch(app.get_Workbooks()); lpDisp = books.Open("D:\\test.xls",covOptional, covOptional, covOptional, covOptional, covOptional,covOptional, covOptional, covOptional, covOptional, covOptional,covOptional, covOptional, covOptional,covOptional); //得到Workbook book.AttachDispatch(lpDisp); //得到Worksheets sheets.AttachDispatch(book.get_Worksheets()); //得到当前活跃sheet //如果有单元格正处于编辑状态中,此操作不能返回,会一直等待 lpDisp=book.get_ActiveSheet(); sheet.AttachDispatch(lpDisp); //读取第一个单元格的值 range.AttachDispatch(sheet.get_Cells()); range.AttachDispatch(range.get_Item (COleVariant((long)2),COleVariant((long)2)).pdispVal); /*COleVariant*/ vResult =range.get_Value2(); CString str; if(vResult.vt == VT_BSTR) //字符串 { str=vResult.bstrVal; } else if (vResult.vt==VT_R8) //8字节的数字 { str.Format("%f",vResult.dblVal); } MessageBox(str); books.Close(); app.Quit(); // 退出 range.ReleaseDispatch(); sheet.ReleaseDispatch(); sheets.ReleaseDispatch(); book.ReleaseDispatch(); books.ReleaseDispatch(); app.ReleaseDispatch(); //OnOK(); }
有读取单元格的函数基本也就差不多了,有想法就去做
相关文章推荐
- keystone之预备知识点
- Android中可自由移动悬浮窗口的实现
- 微信支付爆发,京东移动端弯道超车
- eclipse调试Cts 单项
- [倚天屠龙记] vim 复制与粘贴
- jQuery的三种$()
- Java目录
- @RequestParam的作用
- 【项目管理和构建】十分钟教程,eclipse配置maven + 创建maven项目(三)
- android 调用系统裁剪图片,提示无法保存经过裁剪的图片
- ubuntu 下 visudo的使用
- 关于sql server中的 jion,inner join, left join ,left outer join, right join,right outer join 的几点使用心得
- stvd ubsct溢出错误解决
- 【项目管理和构建】十分钟教程,eclipse配置maven + 创建maven项目(三)
- websocket数据流解析
- PHP 开发工具【2】
- 提升销量技巧
- c语言应该怎么学
- Truncate与Delete的区别
- lambda学习笔记