VS2022 MFC对话框应用OLE读写操作excel

一、添加文件和代码需要包含的库

解决方案资源管理器-工程名称-右键-添加-新建项-MFC-TypeLib中的MFC类-双击或添加-实现接口的位置-文件-点击文件路径旁的 "..." 浏览按钮。你需要找到并选择 EXCEL.EXE 文件。其常见路径为 C:\Program Files\Microsoft Office\root\Office16\EXCEL.EXE(Office 2016及更高版本默认路径)或 C:\Program Files (x86)\Microsoft Office\Office*版本号*\EXCEL.EXE -可用接口_Application、_Workbook、_Worksheet、Range、Workbooks、Worksheets->-实现接口显示对应的名称-确定

二、向导生成的代码通常不能直接编译,还需要做一些清理工作:

  1. 注释冗余导入 :打开刚生成的每个类的头文件(如 CApplication.hCWorkbook.h等),找到类似下面这行的代码并将其注释掉

    复制代码
    // #import "C:\\Program Files\\Microsoft Office\\root\\Office16\\EXCEL.EXE" no_namespace

    如果多个文件都保留这行,编译时会导致类型重复定义

  2. CRange.h会报错:CRange.h(335,10): error C2059: 语法错误:","双击错误直接找到对应的段是VARIANT DialogBox()

    {

    VARIANT result;

    InvokeHelper(0xf5, DISPATCH_METHOD, VT_VARIANT, (void*)&result, nullptr);

    return result;

    }我直接给注释掉了,有解决办法的请给出,谢谢!

三、添加头文件,在pch.h里添加#include "framework.h"

#include "CApplication.h"

#include "CRange.h"

#include "CWorkbook.h"

#include "CWorkbooks.h"

#include "CWorksheet.h"

#include "CWorksheets.h"

#include <afxdisp.h> // ★ OLE 自动化核心

四、在工程的InitInstance()文件里添加if (!AfxOleInit())

{

return false;

}

五、应用

CApplication ExcelApp; //Excel应用程序对象

CWorkbooks wbsMyBooks; //excel工作簿集合对象

CWorkbook wbMyBook; //excel工作簿对象

CWorksheets wssMysheets; //excel工作表集合对象

CWorksheet wsMysheet; //excel单个工作表对象

CRange rgMyRge; //excel单元格范围

CRange iCell;//单个单元格

CString data_w;

//定义一个COleVariant类型的变量covOptional,并将其初始化为一个错误值。

// 这个变量通常用于在调用Excel对象的方法时表示可选参数未提供。

COleVariant covOptional((long)DISP_E_PARAMNOTFOUND, VT_ERROR); //可选参数

//定义一个COleVariant类型的变量vResult,用于存储从Excel单元格中读取的值。

//这个变量可以存储不同类型的数据,例如字符串、数字等。

COleVariant vResult; //存储查询结果

/************************启动Excel******************************/

//创建Excel 2000服务器(启动Excel)

if (!ExcelApp.CreateDispatch("Excel.Application", NULL))

{

AfxMessageBox("创建Excel服务失败!");

exit(1);

}

/************************启动Excel******************************/

/************************打开Excel******************************/

//得到文档

//获取Excel应用程序中的工作簿集合对象,并将其附加到wbsMyBooks变量上。

wbsMyBooks.AttachDispatch(ExcelApp.get_Workbooks(), true); //获取工作簿集合

//在Excel中打开指定路径的工作簿,并将其附加到wbMyBook变量上。

wbMyBook.AttachDispatch(wbsMyBooks.Add(_variant_t(Filepath))); //打开指定文件

//得到Worksheets

wssMysheets.AttachDispatch(wbMyBook.get_Worksheets(), true);//获取工作表集合

//得到sheet1

wsMysheet.AttachDispatch(wssMysheets.get_Item(_variant_t("sheet1")), true); //获取名为"sheet1"的工作表对象

/************************打开Excel******************************/

/************************写入数据*****************************/

rgMyRge.AttachDispatch(wsMysheet.get_Cells()); //获取工作表中的所有单元格,并将其附加到rgMyRge变量上。

//获取当前行(n_row)和第i列的单元格对象,并将其附加到rgMyRge变量上。

rgMyRge.AttachDispatch(rgMyRge.get_Item(COleVariant((long)n_row), COleVariant((long)j)).pdispVal); // 定位到第n_row行第i列

//将m_str数组中对应索引的值写入当前单元格中。

rgMyRge.put_Value2(COleVariant((m_str[j])));//写入对应的数据

/********************写入数据*****************************/

/**********************保存并关闭***************************/

wbMyBook.SaveCopyAs(COleVariant(Filepath));//保存副本 将当前工作簿另存为指定路径的文件。

wbMyBook.Close(COleVariant(short(FALSE)), COleVariant(Filepath), covOptional); //关闭工作簿 关闭工作簿对象,并指定不保存更改,提供文件路径和可选参数。

wbsMyBooks.Close();//关闭工作簿集合对象,释放资源。

ExcelApp.Quit(); //退出Excel应用程序,释放资源。

// 释放所有Dispatch对象

rgMyRge.ReleaseDispatch();

wsMysheet.ReleaseDispatch();

wssMysheets.ReleaseDispatch();

wbMyBook.ReleaseDispatch();

wbsMyBooks.ReleaseDispatch();

ExcelApp.ReleaseDispatch();

/**********************保存并关闭***************************/

相关推荐
967712 小时前
C++多线程2 如何优雅地锁门 (lock_guard) 多线程里的锁的种类
java·开发语言·c++
dddddppppp12313 小时前
mfc实现的贪吃蛇游戏
c++·游戏·mfc
kyle~13 小时前
ROS2 --- WaitSet(等待集) 等待实体就绪,管理执行回调函数
大数据·c++·机器人·ros2
量子炒饭大师13 小时前
【C++进阶】Cyber骇客的赛博血统上传——【面向对象之 继承 】一文带你搞懂面向对象编程的三要素之————继承
c++·dubbo·继承·面向对象编程
Tanecious.14 小时前
蓝桥杯备赛:Day2-B3612 求区间和
c++·蓝桥杯
C+++Python14 小时前
Linux/C++多进程
linux·运维·c++
stolentime14 小时前
通信题:洛谷P15942 [JOI Final 2026] 赌场 / Casino题解
c++·算法·洛谷·joi·通信题
XZHOUMIN14 小时前
【生成pdf格式的报告】
c++·pdf·mfc
elseif12314 小时前
浅谈 C++ 学习
开发语言·c++·学习
沛沛rh4514 小时前
深入并发编程:从 C++ 到 Rust 的学习笔记
c++·笔记·学习·算法·rust