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();

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

相关推荐
大母猴啃编程1 小时前
Socket编程UDP
linux·网络·c++·网络协议·udp
一点 内容1 小时前
企业级 Web Excel 多人实时在线协同:技术实现与核心突破
excel
TE-茶叶蛋2 小时前
从零实现H5 表格协同编辑:Yjs + WebSocket 实战
websocket·小程序·excel
程序喵大人2 小时前
源码剖析:iostream 的缓冲区设计
开发语言·c++·iostream
mr_LuoWei20092 小时前
自定义的中文脚本解释器来实现对excel自动化处理(一)
python·自动化·excel
liu****2 小时前
4.哈希扩展
c++·算法·哈希算法·位图·bitset
70asunflower2 小时前
CUDA基础知识巩固检验练习题【附有参考答案】(6)
c++·人工智能·cuda
仰泳的熊猫2 小时前
题目1882:蓝桥杯2017年第八届真题-k倍区间
数据结构·c++·算法·蓝桥杯
Mikowoo0072 小时前
Visual Studio 2022 下CUDA程序开发
c++·visual studio