c++操作EXCEL
2015-10-13 14:18
344 查看
向Excel表中导出&导入数据
一、 向工程中添加Excel操作接口类
1、 向项目工程中添加基本的7个类,分别是:CApplication,CMyFont,CRange,CWorkBook,CWorkBooks,CWorkSheet,CWorkSheets
1.1、打开Class Wizard,如下图
1.2、选择MFC ClassFrom TypeLib…,如下图
1.3、在Add Class From中选中File,在Location中输入或者选择EXCEL.EXE(officer2007为EXCEL.EXE,officer2003为EXCEL9.OLB)的路径。然后在Interface框(即1号框)中选择操作Excel的基本接口,分别是:_Application,_WorkBook,_WorkSheet, Range,Font,WorkBooks,WorkSheets。点击Generated classes(即2号框)中CFont0类,在classes(即3号框)和File(即4号框)中修改其类名为CMyFont,头文件名为CMyFont.h(类名和头文件名,也可以是其他名字,由自己确定)。点击Finish完成添加。,如下图
1.4、在Class View中可以看见添加进去的7个类,如下图
2、 修改这6个类
2.1、把CApplication.h,CMyFont.h,CRange.h,CWorkBook.h,CWorkBooks.h,CWorkSheet.h,CWorkSheets.h中的“#import "C:\\Program Files\\MicrosoftOffice\\Office12\\EXCEL.EXE" no_namespace”注释掉,然后添加头文件:#include <afxdisp.h>到上面7个文件中去。
3、 添加头文件到要对Excel进行操作的文件中去
4、双击error C2059,将VARIANT DialogBox()改成VARIANT _DialogBox()
再次编译,通过!!
二、 数据导出到EXCEL
1、 程序代码段
//定义接口类变量
CApplication app;
CWorkbookbook;
CWorkbooksbooks;
CWorksheetsheet;
CWorksheetssheets;
CRange range;
CMyFont font;
CRange cols;
COleVariant covOptional((long)
DISP_E_PARAMNOTFOUND,VT_ERROR);
if(!app.CreateDispatch(_T("Excel.Application")))
{
this->MessageBox(_T("无法创建Excel应用!"));
return;
}
books =app.get_Workbooks();
book = books.Add(covOptional);
sheets = book.get_Worksheets();
sheet = sheets.get_Item(COleVariant((short)1));
//获得坐标为(A,1)和(B,1)的两个单元格
range = sheet.get_Range(COleVariant(_T("A1")),
COleVariant(_T("B1")));
//设置单元格类容为HelloExcel
range.put_Value2(COleVariant(_T("HelloExcel")));
//选择整列,并设置宽度为自适应
cols = range.get_EntireColumn();
cols.AutoFit();
//设置字体为粗体
font = range.get_Font();
font.put_Bold(COleVariant((short)TRUE));
//获得坐标为(C,2)单元格
range = sheet.get_Range(COleVariant(_T("C2")),
COleVariant(_T("C2")));
//设置公式“=RAND()*100000”
range.put_Formula(COleVariant(_T("=RAND()*100000")));
//设置数字格式为货币型
range.put_NumberFormat(COleVariant(_T("$0.00")));
//选择整列,并设置宽度为自适应
cols = range.get_EntireColumn();
cols.AutoFit();
//显示Excel表
app.put_Visible(TRUE);
app.put_UserControl(TRUE);
三、 数据从Excel导入到程序中
1、 程序代码段
CApplication app;
CWorkbook book;
CWorkbooks books;
CWorksheet sheet;
CWorksheets sheets;
CRange range;
LPDISPATCH lpDisp;
//定义变量
COleVariant covOptional((long)
DISP_E_PARAMNOTFOUND,VT_ERROR);
if(!app.CreateDispatch(_T("Excel.Application")))
{
this->MessageBox(_T("无法创建Excel应用"));
return;
}
books =app.get_Workbooks();
//打开Excel,其中pathname为Excel表的路径名
lpDisp =books.Open(pathname,covOptional
,covOptional,covOptional,covOptional
,covOptional,covOptional,covOptional
,covOptional,covOptional,covOptional
,covOptional,covOptional,covOptional
,covOptional);
book.AttachDispatch(lpDisp);
sheets = book.get_Worksheets();
sheet = sheets.get_Item(COleVariant((short)1));
//获得坐标为(A,1)的单元格
range =sheet.get_Range(COleVariant(_T("A1"))
,COleVariant(_T("A1")));
//获得单元格的内容
COleVariant rValue;rValue =
COleVariant(range.get_Value2());
//转换成宽字符
rValue.ChangeType(VT_BSTR);
//转换格式,并输出
this->MessageBox(CString(rValue.bstrVal));
book.put_Saved(TRUE);
app.Quit();
一、 向工程中添加Excel操作接口类
1、 向项目工程中添加基本的7个类,分别是:CApplication,CMyFont,CRange,CWorkBook,CWorkBooks,CWorkSheet,CWorkSheets
1.1、打开Class Wizard,如下图
1.2、选择MFC ClassFrom TypeLib…,如下图
1.3、在Add Class From中选中File,在Location中输入或者选择EXCEL.EXE(officer2007为EXCEL.EXE,officer2003为EXCEL9.OLB)的路径。然后在Interface框(即1号框)中选择操作Excel的基本接口,分别是:_Application,_WorkBook,_WorkSheet, Range,Font,WorkBooks,WorkSheets。点击Generated classes(即2号框)中CFont0类,在classes(即3号框)和File(即4号框)中修改其类名为CMyFont,头文件名为CMyFont.h(类名和头文件名,也可以是其他名字,由自己确定)。点击Finish完成添加。,如下图
1.4、在Class View中可以看见添加进去的7个类,如下图
2、 修改这6个类
2.1、把CApplication.h,CMyFont.h,CRange.h,CWorkBook.h,CWorkBooks.h,CWorkSheet.h,CWorkSheets.h中的“#import "C:\\Program Files\\MicrosoftOffice\\Office12\\EXCEL.EXE" no_namespace”注释掉,然后添加头文件:#include <afxdisp.h>到上面7个文件中去。
3、 添加头文件到要对Excel进行操作的文件中去
4、双击error C2059,将VARIANT DialogBox()改成VARIANT _DialogBox()
再次编译,通过!!
二、 数据导出到EXCEL
1、 程序代码段
//定义接口类变量
CApplication app;
CWorkbookbook;
CWorkbooksbooks;
CWorksheetsheet;
CWorksheetssheets;
CRange range;
CMyFont font;
CRange cols;
COleVariant covOptional((long)
DISP_E_PARAMNOTFOUND,VT_ERROR);
if(!app.CreateDispatch(_T("Excel.Application")))
{
this->MessageBox(_T("无法创建Excel应用!"));
return;
}
books =app.get_Workbooks();
book = books.Add(covOptional);
sheets = book.get_Worksheets();
sheet = sheets.get_Item(COleVariant((short)1));
//获得坐标为(A,1)和(B,1)的两个单元格
range = sheet.get_Range(COleVariant(_T("A1")),
COleVariant(_T("B1")));
//设置单元格类容为HelloExcel
range.put_Value2(COleVariant(_T("HelloExcel")));
//选择整列,并设置宽度为自适应
cols = range.get_EntireColumn();
cols.AutoFit();
//设置字体为粗体
font = range.get_Font();
font.put_Bold(COleVariant((short)TRUE));
//获得坐标为(C,2)单元格
range = sheet.get_Range(COleVariant(_T("C2")),
COleVariant(_T("C2")));
//设置公式“=RAND()*100000”
range.put_Formula(COleVariant(_T("=RAND()*100000")));
//设置数字格式为货币型
range.put_NumberFormat(COleVariant(_T("$0.00")));
//选择整列,并设置宽度为自适应
cols = range.get_EntireColumn();
cols.AutoFit();
//显示Excel表
app.put_Visible(TRUE);
app.put_UserControl(TRUE);
三、 数据从Excel导入到程序中
1、 程序代码段
CApplication app;
CWorkbook book;
CWorkbooks books;
CWorksheet sheet;
CWorksheets sheets;
CRange range;
LPDISPATCH lpDisp;
//定义变量
COleVariant covOptional((long)
DISP_E_PARAMNOTFOUND,VT_ERROR);
if(!app.CreateDispatch(_T("Excel.Application")))
{
this->MessageBox(_T("无法创建Excel应用"));
return;
}
books =app.get_Workbooks();
//打开Excel,其中pathname为Excel表的路径名
lpDisp =books.Open(pathname,covOptional
,covOptional,covOptional,covOptional
,covOptional,covOptional,covOptional
,covOptional,covOptional,covOptional
,covOptional,covOptional,covOptional
,covOptional);
book.AttachDispatch(lpDisp);
sheets = book.get_Worksheets();
sheet = sheets.get_Item(COleVariant((short)1));
//获得坐标为(A,1)的单元格
range =sheet.get_Range(COleVariant(_T("A1"))
,COleVariant(_T("A1")));
//获得单元格的内容
COleVariant rValue;rValue =
COleVariant(range.get_Value2());
//转换成宽字符
rValue.ChangeType(VT_BSTR);
//转换格式,并输出
this->MessageBox(CString(rValue.bstrVal));
book.put_Saved(TRUE);
app.Quit();
相关文章推荐
- C++ BOOST库 条件变量[多线程通信]机制 简单介绍
- HDU 1312 Red and Black(dfs)
- C++中Format的用法
- 爬爬爬之路:C语言(四) 一维数组篇
- The differences between new(delete) and malloc(free) in c/c++
- C++第六课 函数1
- c语言实现模拟发送报文改进版(添加程序自动打log)
- Leecode_Count Primes
- C++ 用户自定义类型
- Leetcode NO.8 String to Integer (atoi)
- C语言:标准输入读取几行输入。每行输入都要打印到标准输出上,前面加上行号。行号不能有限制
- C语言:编写程序求解:有1,2,3,4,个数字,将组成互不相同且无重复数字出现的三位数打印出来
- C语言:编这样一个程序,用户输入10个整数,程序找出其中的最大值和最小值
- C语言:编写猜数字游戏,猜一个数字,一直到猜中为止
- C语言:编写折半查找函数,即二分法
- C++入门学习——explicit关键字的作用
- 【C语言】 猜数字游戏
- 几种常见排序算法的C++描述
- C语言字符串
- C语言中函数参数入栈的顺序