用VC对Excel文件进行写操作后,在程序结束前需要对一些对象进行收尾工作,如调用_Workbook::Save()方法(该方法是Microsoft提供的供VC调用的对Excel文件操作的标准方法,在文件excel9.cpp或excel.cpp中定义)保存文件。
问题就出现在这里,若选取要保存的Excel文件以前不存在则程序创建一个同名的空Excel文件,对Excel表的操作实际是对其同名副本的操作,Save()方法会触发一个"另存为"的对话框,需要覆盖原来同名的空Excel文件,否则写入Excel的数据会丢失。若选取的Excel文件已经存在,则调用Save()方法不会触发"另存为"对话框,系统会自动保存写到Excel中的数据。
需要说明的是,在调用Save()前,已经调用过SetAlertBeforeOverwriting(FALSE)和SetDisplayAlerts(FALSE)关掉一些警告窗口了。若调用SaveAs()方法,虽不会触发"另存为"对话框,但会出抛出“找不到成员”的错误,这时保存写好的Excel文件后并重新打开发现数据还是丢失。
想尽所有办法,可总无法去掉那个讨厌的"另存为"对话框,请各位大虾帮忙。多谢了!
SaveAs()是excelapp的方法吗。
xlApp.ActiveWorkbook.SaveAs"C:\excel.xls"
xlApp.Quit
我的没有问题。
如今Excel是越来越重要了,在我们自己开发的程序中不免要和Excel打交道了。利用Automation技术,我们可以在不去了解
数据库的情况下玩转Excel,而且你会发现一切竟如此轻松!
好了,咱们开始吧,我不喜欢用长篇累牍的代码来故弄玄虚,所以下面的代码都是切中要害的片段,总体上是个连贯的过程,
包括启动Excel,读取数据,写入数据,以及最后的关闭Excel,其中还包括了很多人感兴趣的合并单元格的处理。
特别说明以下代码需要MFC的支持,而且工程中还要包含EXCEL2000的定义文件:EXCEL9.H,EXCEL9.CPP
*****************************************************************************************************************
//*****
//变量定义
_Applicationapp;
Workbooksbooks;
_Workbookbook;
Worksheetssheets;
_Worksheetsheet;
Rangerange;
RangeiCell;
LPDISPATCHlpDisp;
COleVariantvResult;
COleVariant
covTrue((short)TRUE),
covFalse((short)FALSE),
covOptional((long)DISP_E_PARAMNOTFOUND,VT_ERROR);
//*****
//初始化COM的动态连接库
if(!AfxOleInit())
{
AfxMessageBox("无法初始化COM的动态连接库!");
return;
}
//*****
//创建Excel2000服务器(启动Excel)
if(!app.CreateDispatch("Excel.Application"))
{
AfxMessageBox("无法启动Excel服务器!");
return;
}
app.SetVisible(TRUE);//使Excel可见
app.SetUserControl(TRUE);//允许其它用户控制Excel
//*****
//打开c:\\1.xls
books.AttachDispatch(app.GetWorkbooks());
lpDisp=books.Open("C:\\\\1.xls",
covOptional,covOptional,covOptional,covOptional,covOptional,
covOptional,covOptional,covOptional,covOptional,covOptional,
covOptional,covOptional);
//*****
//得到Workbook
book.AttachDispatch(lpDisp);
//*****
//得到Worksheets
sheets.AttachDispatch(book.GetWorksheets());
//*****
//得到当前活跃sheet
//如果有单元格正处于编辑状态中,此操作不能返回,会一直等待
lpDisp=book.GetActiveSheet();
sheet.AttachDispatch(lpDisp);
//*****
//读取已经使用区域的信息,包括已经使用的行数、列数、起始行、起始列
RangeusedRange;
usedRange.AttachDispatch(sheet.GetUsedRange());
range.AttachDispatch(usedRange.GetRows());
longiRowNum=range.GetCount();//已经使用的行数
range.AttachDispatch(usedRange.GetColumns());
longiColNum=range.GetCount();//已经使用的列数
longiStartRow=usedRange.GetRow();//已使用区域的起始行,从1开始
longiStartCol=usedRange.GetColumn();//已使用区域的起始列,从1开始
//*****
//读取第一个单元格的值
range.AttachDispatch(sheet.GetCells());
range.AttachDispatch(range.GetItem(COleVariant((long)1),COleVariant((long)1)).pdispVal);
COleVariantvResult=range.GetValue();
CStringstr;
if(vResult.vt==VT_BSTR)//字符串
{
str=vResult.bstrVal;
}
elseif(vResult.vt==VT_R8)//8字节的数字
{
str.Format("%f",vResult.dblVal);
}
elseif(vResult.vt==VT_DATE)//时间格式
{
SYSTEMTIMEst;
VariantTimeToSystemTime(&vResult.date,&st);
}
elseif(vResult.vt==VT_EMPTY)//单元格空的
{
str="";
}
//*****
//读取第一个单元格的对齐方式,数据类型:VT_I4
//读取水平对齐方式
range.AttachDispatch(sheet.GetCells());
iCell.AttachDispatch((range.GetItem(COleVariant(long(1)),COleVariant(long(1)))).pdispVal);
vResult.lVal=0;
vResult=iCell.GetHorizontalAlignment();
if(vResult.lVal!=0)
{
switch(vResult.lVal)
{
case1://默认
break;
case-4108://居中
break;
case-4131://靠左
break;
case-4152://靠右
break;
}
}
//垂直对齐方式
iCell.AttachDispatch((range.GetItem(COleVariant(long(1)),COleVariant(long(1)))).pdispVal);
vResult.lVal=0;
vResult=iCell.GetVerticalAlignment();
if(vResult.lVal!=0)
{
switch(vResult.lVal)
{
case-4160://靠上
break;
case-4108://居中
break;
case-4107://靠下
break;
}
}
//*****
//设置第一个单元格的值"HI,EXCEL!"
range.SetItem(COleVariant(1),COleVariant(1),COleVariant("HI,EXCEL!"));
//*****
//设置第一个单元格字体颜色:红色
Fontfont;
range.AttachDispatch(sheet.GetCells());
range.AttachDispatch((range.GetItem(COleVariant(long(1)),COleVariant(long(1)))).pdispVal);
font.SetColor(COleVariant((long)0xFF0000));
//*****
//合并单元格的处理
//包括判断第一个单元格是否为合并单元格,以及将第一个单元格进行合并
RangeunionRange;
range.AttachDispatch(sheet.GetCells());
unionRange.AttachDispatch(range.GetItem(COleVariant((long)1),COleVariant((long)1)).pdispVal);
vResult=unionRange.GetMergeCells();
if(vResult.boolVal==-1)//是合并的单元格
{
//合并单元格的行数
range.AttachDispatch(unionRange.GetRows());
longiUnionRowNum=range.GetCount();
//合并单元格的列数
range.AttachDispatch(unionRange.GetColumns());
longiUnionColumnNum=range.GetCount();
//合并区域的起始行,列
longiUnionStartRow=unionRange.GetRow();//起始行,从1开始
longiUnionStartCol=unionRange.GetColumn();//起始列,从1开始
}
elseif(vResult.boolVal==0)
{//不是合并的单元格}
//将第一个单元格合并成2行,3列
range.AttachDispatch(sheet.GetCells());
unionRange.AttachDispatch(range.GetItem(COleVariant((long)1),COleVariant((long)1)).pdispVal);
unionRange.AttachDispatch(unionRange.GetResize(COleVariant((long)2),COleVariant((long)3)));
unionRange.Merge(COleVariant((long)0));//合并单元格
//*****
//将文件保存为2.xls
book.SaveAs(COleVariant("C:\\\\2.xls"),covOptional,covOptional,\\
covOptional,covOptional,covOptional,0,\\
covOptional,covOptional,covOptional,covOptional);
//*****
//关闭所有的book,退出Excel
book.Close(covOptional,COleVariant(OutFilename),covOptional);
books.Close();
app.Quit();
//Excel保存
Sheet.OleProcedure("SaveAs",FName.c_str());
分享到:
相关推荐
"vc读写excel文件"这个主题涉及到的是使用Visual C++(VC)编程语言与Excel进行交互,实现对Excel文件的读取和写入操作。以下是一些关于这个主题的关键知识点: 1. **Microsoft Office Interop**: 这是Microsoft...
本文将深入探讨如何使用Visual C++(VC)来读取和写入Excel文件,主要涉及Microsoft Office的自动化接口,以及可能用到的第三方库。 一、Microsoft Office自动化接口 微软提供了一种称为“Automation”的技术,允许...
在VC++环境中,使用Microsoft Foundation Classes (MFC)来操作Excel文件可以实现对Excel的创建、编辑和保存功能。MFC是微软为Windows应用程序开发提供的一套类库,它基于C++并封装了Windows API,使得开发者能更方便...
本主题聚焦于“VC操作Excel文件”,特别是在VS2008环境下如何实现这一功能。VS2008是微软提供的一个强大的集成开发环境,支持C++编程,包括对Office应用程序如Excel的接口调用。 在VS2008中操作Excel文件,通常会...
本资源"Excel文件操作 数据库 vc 源码"提供了使用Visual C++(简称VC)进行Excel文件操作的方法,将Excel文档视为数据库来读取和写入数据。下面我们将深入探讨这个主题。 首先,VC是Microsoft开发的C++集成开发环境...
本文将详细讲解如何通过VC++来实现对Excel文件的读取和写入操作,主要关注以下几个方面:Excel API接口的使用、工作簿与工作表的管理和数据的读写操作。 首先,我们需要知道,微软提供的COM(Component Object ...
在VC++开发环境中,操作Excel文件通常涉及到对Microsoft Office Automation接口的使用,或者利用第三方库进行数据交换。本文将深入探讨VC++如何读写Excel文件,重点介绍CSpreadSheet类的使用及其背后的原理。 首先...
这个“VC操作Excel类”应该提供了一个简洁的接口,使得开发者可以通过C++代码来创建、读取和修改Excel文件。下面,我们将详细讨论如何在VC6.0下实现这些功能以及相关知识点。 首先,你需要包含必要的头文件和库,如...
这个程序的目的就是展示如何通过VC来操作Excel文件,激发更多的编程思路。 首先,我们要理解VC如何与Excel进行通信。在VC中,我们可以利用COM组件来实例化Excel应用对象,然后调用其提供的方法和属性。例如,我们...
本知识点主要围绕如何在VC项目中使用自定义的`ExcelProc`类来简化Excel文件的编程工作。 `ExcelProc.cpp`和`ExcelProc.h`是两个关键文件,它们提供了对Excel文件进行读写和操作的封装。`ExcelProc.cpp`包含了实现...
本文将详细介绍如何使用VC++来创建、访问Excel文件,并提供基础的操作指南。 首先,我们需要包含必要的头文件,主要是`#import`指令来引入Excel的库文件,例如: ```cpp #import "libid:00020813-0000-0000-C000-...
VC操作Excel主要是通过COM(Component Object Model)接口来实现的,这允许VC++应用程序与Excel进行交互,控制Excel的工作流程,比如创建、打开、编辑、保存Excel文件等。以下是详细的知识点: 1. **添加引用**: ...
6. **保存和关闭工作簿**:将修改保存到Excel文件,或者关闭工作簿和应用程序。 在`excel9.h`和`MyExcel.h`中,我们可能看到以下内容: 1. 类声明:定义了一个或多个类,如`ExcelManager`或`MyExcel`,它们封装了...
这个“vc读取excel文件demo.zip”压缩包提供了一个使用MFC(Microsoft Foundation Classes)框架来读取和写入Excel文件的示例。MFC是微软为C++开发者设计的一个类库,它简化了Windows API的使用,让开发者可以更方便...
在VC++环境中,将数据保存为Excel格式通常涉及到使用Microsoft的COM接口,即自动化服务器(Automation Server)来操作Excel应用程序对象。以下是一个详细的步骤指南,教你如何在VC++中实现这个功能: 1. **理解COM...
将VC控制EXCEL文件的一些基本方法封装成了一个名叫CExcelApp的类,本人也是新手,VC学习4个月,大家共同学习。 /*------------------------------------------------------------------------------------------ ...
在IT行业中,使用VC(Visual C++)进行Excel操作是一项常见的任务,特别是在数据处理和自动化工作流程中。这里我们将深入探讨如何使用VC与Excel交互,主要涉及的知识点包括API调用、COM接口以及OLE自动化。 1. **...
在"vc读写excel文件示例"中,可能包含以下步骤: 1. **引入必要的头文件**:首先,我们需要包含`#import`指令来导入Excel的自动化库,如`#import "libid:00020813-0000-0000-C000-000000000046" no_namespace named...
用VC6.0来读取Excel文件中的数据; 用VC6.0来生成一个Excel文件。