MFC中使用EXCEL的方法之一

1、导入EXCEL控件

打开类向导,添加类型库中的MFC类

选择文件来源,打开EXCEL.EXE所在的文件路径

然后添加如下图所示的几个类,这几个类可以满足基本的读写

然后把新添加的这几个类中头文件中的 #import注释掉

当引用头文件准备使用时,会发现有个错误,此时在DialogBox()前增加一个下划线,变成VARIANT _DialogBox() 就可以正常使用了

2、初始化Ole环境

在程序初始化之后调用AfxOleInit();

在程序关闭之前调用AfxOleTerm();

3、调用

初始化EXCEL调用环境

cpp 复制代码
CApplication excelApp;
//启动Excel
if (!excelApp.CreateDispatch(_T("Excel.Application"), NULL))
{
	AfxMessageBox(_T("启动Excel失败!"));
	return FALSE;
}

获取工作簿和sheet页(EXCEL已经存在)

cpp 复制代码
    CWorkbook book;
	CWorkbooks books;
	CWorksheets sheets;
	CWorksheet sheet;

	// 解析EXCEL
	COleVariant
		covTrue((short)TRUE),
		covFalse((short)FALSE),
		covOptional((long)DISP_E_PARAMNOTFOUND, VT_ERROR);

	books.AttachDispatch(excelApp.get_Workbooks(), TRUE);
	book = books.Open(strExcelPath, covOptional, covOptional, covOptional,
		covOptional, covOptional, covOptional, covOptional,
		covOptional, covOptional, covOptional, covOptional,
		covOptional, covOptional, covOptional);

	sheets = book.get_Worksheets();
	//获取第一个工作表
	sheet = sheets.get_Item(COleVariant((short)1));

创建一个新的工作簿

cpp 复制代码
CWorkbook bookNew = books.Add(covOptional);

对EXCEL的数据进行操作

cpp 复制代码
CRange usedRange;

usedRange.AttachDispatch(sheet.get_Cells(), TRUE);

// 或者如下(AttachDispatch和等于是两种不同的使用方式)
usedRange = sheet.get_UsedRange();


// 获取某个单元格,i,j从1开始
usedRange.AttachDispatch(usedRange.get_Item(COleVariant(long(i)), COleVariant(long(j))).pdispVal, TRUE);

// 或者如下
usedRange= usedRange.get_Item(COleVariant(long(i)), COleVariant(long(j))).pdispVal;

usedRange.put_Item(COleVariant(long(i)), COleVariant(long(j)), COleVariant(_T("文字内容"));

// 如果需要写入数字,则需要先设置格式,如下:
usedRange.put_NumberFormat(COleVariant(_T("@")));
usedRange.put_Item(COleVariant(long(i)), COleVariant(long(j)), COleVariant(_T("2025"));

// 读取或者写入单个单元格,还可以使用
COleVariant ret = usedRange.get_Value2();
usedRange.put_Value2(ret);

释放引用及保存EXCEL文件

cpp 复制代码
//保存
book.SaveCopyAs(COleVariant(strExcelPath));  //SaveCopyAs在strFile路径下保存为指定格式.xlsx的文件

book.put_Saved(TRUE);   //将Workbook的保存状态设置为已保存,即不让系统提示是否人工保存
	
// 释放各种引用
usedRange.ReleaseDispatch();

sheet.ReleaseDispatch();
sheets.ReleaseDispatch();
book.ReleaseDispatch();

books.ReleaseDispatch();

books.Close();

退出EXCEL操作

cpp 复制代码
	excelApp.Quit();
	excelApp.ReleaseDispatch();
相关推荐
萌新小码农‍2 小时前
SpringBoot+alibaba的easyexcel实现前端使用excel表格批量插入
前端·spring boot·excel
滴_咕噜咕噜8 小时前
【MFC】sqlite3数据库类导入MFC项目调用
sqlite·mfc
R-G-B15 小时前
【23】MFC入门到精通——MFC资源视图 报错“在另一个编辑器中打开” ,MFC Dialog窗口消失 资源视图“在另一个编译器中打开”
c++·编辑器·mfc·“在另一个编辑器中打开”·mfc dialog窗口消失
petunsecn16 小时前
Excel文件中的VBA脚本,在文件使用WPS编辑保存后无法执行
excel·wps
一路向北⁢21 小时前
基于 Apache POI 5.2.5 构建高效 Excel 工具类:从零到生产级实践
java·apache·excel·apache poi·easy-excel·fast-excel
Java小王子呀1 天前
Java实现Excel转PDF
java·pdf·excel
滴_咕噜咕噜2 天前
【MFC】数据库操作:数据库动态生成
数据库·c++·mfc
缺点内向2 天前
Java:创建、读取或更新 Excel 文档
java·excel
R-G-B2 天前
【25】MFC入门到精通——MFC静态文本框 中字符串 连续输出 不覆盖先前的文本 换行输出
c++·mfc·mfc静态文本框输出字符串·mfc静态文本框连续输出字符串·mfc静态文本框换行输出字符串
wangbing11252 天前
EXCEL文本数字如何批量转换为数字
excel