VS2010 MFC读取Excel文件中数据

VS2010 MFC读取Excel文件中数据前段时间写个工具需要从Excel文件中读取数据,Excel表格数据列数为确定值,行数不确定,从网上搜了些方法尝试,最终达到目的,总结如下:

大家好,又见面了,我是你们的朋友全栈君。

前段时间写个工具需要从Excel文件中读取数据,Excel表格数据列数为确定值,行数不确定,从网上搜了些方法尝试,最终达到目的,总结如下:

1. 新建一个基于对话框的MFC应用程序

2. 添加Excel相关类

打开类向导,添加类下拉框选择类型库中的MFC类,来源选择注册表(不容易出错),可用的类型库选择”Microsoft Excel …”(根据Excel的版本有所不同);接口选择:_Application,_WorkSheet,_WorkBook,Range,WorkSheets,WorkBooks;添加6个必要的类CApplication,CWorkbook,CWorksheet,CRange,CWorkbooks,CWorksheets

VS2010 MFC读取Excel文件中数据

3. 添加完成后,找到相关头文件,注释或删除:

//#import "D:\\Program Files (x86)\\Microsoft Office\\Office14\\EXCEL.EXE" no_namespace

在stdafx.h中添加:

#include "CApplication.h"
#include "CRange.h"
#include "CWorkbook.h"
#include "CWorkbooks.h"
#include "CWorksheet.h"
#include "CWorksheets.h"

4. 编译出现错误:

1>e:\vs2010_project\demo\mfcexcel\crange.h(335): warning C4003: “DialogBoxW”宏的实参不足
1>e:\vs2010_project\demo\mfcexcel\crange.h(335): error C2059: 语法错误:“,”

解决方法:定位错误信息,在CRange类中将DialogBox()改为_DialogBox()

	VARIANT _DialogBox()
	{
		VARIANT result;
		InvokeHelper(0xf5, DISPATCH_METHOD, VT_VARIANT, (void*)&result, NULL);
		return result;
	}

5. 获取Excel文件路径全名(包括文件名)

添加一个打开文件按钮和显示路径的编辑框,按钮单击消息处理函数:

void COfflineDlg::OnBnClickedButtonOpenfile()
{
	// TODO: 在此添加控件通知处理程序代码
	CFileDialog file(TRUE,NULL,NULL,OFN_HIDEREADONLY|OFN_OVERWRITEPROMPT,  
		_T("EXCEL文件(*.xls;*.xlsx)|*.xls;*.xlsx||"),AfxGetMainWnd());  
	if(file.DoModal()==IDOK)  
	{  
		strPath=file.GetPathName();  
		GetDlgItem(IDC_EDIT_FilePath)->SetWindowText(strPath);
	}  
}

strPath为CString类型的对话框成员变量,用于存储路径

6. 读取Excel中数据

添加一个读取数据按钮,按钮单击消息处理函数:

void COfflineDlg::OnBnClickedButtonReaddata()
{
	// TODO: 在此添加控件通知处理程序代码
	if("" == strPath)
	{
		theApp.ShowInfo(_T("请先选择文件"));
		return;
	}

	GetDlgItem(IDC_BUTTON_ReadData)->EnableWindow(FALSE);
	theApp.ShowInfo(_T("读取数据..."));

	CApplication app;	//Excel程序
	CWorkbooks books;	//工作簿集合
	CWorkbook book;		//工作簿
	CWorksheets sheets;	//工作表集合 
	CWorksheet sheet;	//工作表
	CRange range;		//使用区域

	COleVariant covOptional((long)DISP_E_PARAMNOTFOUND, VT_ERROR);  
	if (!app.CreateDispatch(_T("Excel.Application")))  
	{  
		MessageBox(_T("Error!Creat Excel Application Server Fail!"));  
		exit(1);  
	}  

	books.AttachDispatch(app.get_Workbooks(),true); 
	book.AttachDispatch(books.Add(_variant_t(strPath)));//获取选择的Excel文件
	sheets.AttachDispatch(book.get_Worksheets(),true);//获取文件中的所有sheet
	sheet.AttachDispatch(sheets.get_Item(_variant_t("sheet1")),true);//获取sheet1区域

	vstrCycleSets.clear();
	vstrCmdSeque.clear();
	vstrSendData.clear();
	vstrExpectData.clear();
	vstrTimeout.clear();
	vstrCheck.clear();
	vstrCycleCnt.clear();

	CString str;
	bool bExit = false;
	for(int irow=2;!bExit;irow++)
	{
		for(int icolumn=1;icolumn<8;icolumn++)
		{
			range.AttachDispatch(sheet.get_Cells(),true);//获取sheet1所有的单元格,重置当前区域为A1
			range.AttachDispatch(range.get_Item (COleVariant((long)irow),COleVariant((long)icolumn)).pdispVal);//获取单元格
			switch(icolumn)
			{
			case 1: str = range.get_Value2(); 
					if(str.IsEmpty())
					{
						bExit = true; 
						break;
					}
					vstrCycleSets.push_back(str); 
					break;
			case 2: str = range.get_Value2();
					vstrCmdSeque.push_back(str);
					break;
			case 3: str = range.get_Value2();
					str.Replace(" ", "");
					vstrSendData.push_back(str);
					break;
			case 4: str = range.get_Value2();
					str.Replace(" ", "");
					vstrExpectData.push_back(str);
					break;
			case 5: str = range.get_Value2();
					vstrTimeout.push_back(str);
					break;
			case 6: str = range.get_Value2();
					vstrCheck.push_back(str);
					break;
			case 7: str = range.get_Value2();
					vstrCycleCnt.push_back(str);
					break;
			default: ;
			}
			if(bExit)
			{
				break;
			}
		}
	}

	range.ReleaseDispatch();//释放对象
	sheet.ReleaseDispatch();
	sheets.ReleaseDispatch();
	book.ReleaseDispatch();  
	books.ReleaseDispatch();    
	app.ReleaseDispatch(); 
	app.Quit();//退出Excel程序

	if(!vstrCycleSets.empty())
	{
		theApp.ShowInfo(_T("读取数据成功"));
	}
	else
	{
		theApp.ShowInfo(_T("读取数据失败"));
	}

	GetDlgItem(IDC_BUTTON_ReadData)->EnableWindow(TRUE);
}

我读取的Excel表格数据列数固定为7,数据不确定所以行数不确定,第一行为表头,所以从第二行A2单元格开始读,通过Ai是否为空来判断数据是否读完。采用容器来保存数据对象比较方便,容器定义为对话框成员变量:

	//存储Excel读取的数据
	vector<CString> vstrCycleSets;
	vector<CString> vstrCmdSeque;
	vector<CString> vstrSendData;
	vector<CString> vstrExpectData;
	vector<CString> vstrTimeout;
	vector<CString> vstrCheck;
	vector<CString> vstrCycleCnt;

至此,就完成了从Excel中读取数据。

我们都是站在巨人的肩膀上,参考资料:

http://blog.csdn.net/u013507368/article/details/42143913

http://blog.csdn.net/jason___bourne/article/details/39643419

http://blog.csdn.net/fkzh2651/article/details/12185611

http://blog.csdn.net/tc297520702/article/details/20745457

http://blog.csdn.net/wangzhiyang925/article/details/37572695

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/150086.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 变电站后台监控系统[通俗易懂]

    变电站后台监控系统[通俗易懂]变电站后台监控系统实现对35KV变电站的主要设备和输、配电线路的自动监视、测量、自动控制和微机保护,以及与调度通信等综合性的自动化功能。实现对电网运行的实时监控,使值班人员和系统调度人员通过管理平台及时把握系统的运行状态和事故处理的主动性,另外配套的手机客户端软件实现了移动终端功能,可随时随地查看或管理电网,提高电网的自动化管理水平、供电质量。为达到这一目的,满足电网运行对变电站后台监控系统的要求,变电站综合电力自动化系统体系由“数据采集和控制”、“继电保护”、“直流电源系统”三大块构成变电站自动化基础。

    2022年7月25日
    14
  • idea多多激活码(最新序列号破解)

    idea多多激活码(最新序列号破解),https://javaforall.net/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

    2022年3月18日
    238
  • 无人机的电路板和控制器_无人机飞控电路图

    无人机的电路板和控制器_无人机飞控电路图第1步,查看官方ESP-Drone无人机ESP32-S2-WROVER模块的参考设计原理图第二步,用KiCAD绘制ESP32-S2-WROVER模块及周边电路。1、如图2-1所示,从KiCAD的原理图符号库中直接调出ESP32-S2-WROVER的原理图符号。注意,在安装KiCAD软件后,它的原理图符号库中已经有ESP32-S2-WROVER的原理图符号,可以直接调用,对于没有的原理图符号,可以进行自己创建。2、如图2-2所示,给ESP32-S2-WROVER模块…

    2022年8月15日
    9
  • autoconf 英文手册

    autoconf 英文手册1IntroductionAphysicist,anengineer,andacomputerscientistwerediscussingthenatureofGod.“SurelyaPhysicist,”saidthephysicist,“becauseearlyintheCreation,GodmadeLight;and…

    2022年6月4日
    34
  • 史上最详细的IDEA优雅整合Maven+SSM框架(详细思路+附带源码)

    史上最详细的IDEA优雅整合Maven+SSM框架(详细思路+附带源码)网上很多整合SSM博客文章并不能让初探ssm的同学思路完全的清晰,可以试着关掉整合教程,摇两下头骨,哈一大口气,就在万事具备的时候,开整,这个时候你可能思路全无~中招了咩~,还有一些同学依旧在使用eclipse或者Myeclipse开发,我想对这些朋友说IDEA的编译速度很快,人生苦短,来不及解释了,直接上手idea吧。这篇文章每一步搭建过程都测试过了,应该不会有什么差错。本文章还有个比较优秀的特点,就是idea的使用,基本上关于idea的操作都算是比较详细的,所以不用太担心不会撸idea!最后,本文

    2022年6月14日
    33
  • 独热编码(One-Hot Encoding)介绍及实现

    独热编码(One-Hot Encoding)介绍及实现一、介绍One-Hot编码,又称为一位有效编码,主要是采用位状态寄存器来对个状态进行编码,每个状态都由他独立的寄存器位,并且在任意时候只有一位有效。独热编码是利用0和1表示一些参数,使用N位状态寄存器来对N个状态进行编码。例如:参考数字手写体识别中:如数字字体识别0~9中,6的独热编码为0000001000自然状态码为:000,001,010,011,100,101…

    2025年8月20日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号