EXCEL类型库的添加

1. 创建新的C++工程

  创建基于对话框的MFC程序

2. 添加库、添加Excel类库

在工程名上右键,选择“添加”—“类”(或者点击菜单栏的“项目”->“添加类”),选择“TypeLib中的MFC类”(MFC Class From TypeLib)

类来源选“注册表”,在可用的类型库中选择“Microsoft Excel 11.0 Object Library<1.5>”在接口列表框中选择需要的类,在此,我们选择_Application,_Workbook,Worksheet,Range,Workbooks,Worksheets这六个就可以了。

修改头文件

分别将加进来的六个头文件上面的“#import "C:\\Program Files\\Microsoft Office\\OFFICE11\\EXCEL.EXE" no_namespace”注释掉。

4. 添加头文件

在stdAfx.h头文件中添加加进来的这几个头文件

#include "CApplication.h"

#include "CRange.h"

#include "CWorkbook.h"

#include "CWorkbooks.h"

#include "CWorksheet.h"

#include "CWorksheets.h"

5. 修改错误

编译,会出现两个错误:

…\crange.h(335): warning C4003: “DialogBoxW”宏的实参不足

…\crange.h(335): error C2059: 语法错误:“,”

双击错误提示,定位在错误行,

VARIANT DialogBox()

{

VARIANT result;

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

return result;

}

将该函数名“DialogBox()”前面加“_”下划线,即“_DialogBox()”,这样就可以编译成功了。

6. 在对话框中添加一个编辑框,并为其关联一CEdit类型变量m_Path,添加“打开”按钮,实现打开一已经存在的Excel文件。并将路径显示在编辑框中。实现代码如下。

void CExportToExcelDlg::OnBnClickedButtonOpen()

{

CFileDialog file(TRUE,NULL,NULL,OFN_HIDEREADONLY|OFN_OVERWRITEPROMPT,

_T("EXCEL文件t(*.xls;*.xlsx)|*.xls;*.xlsx||"),AfxGetMainWnd());

if(file.DoModal()==IDOK)

{

CString strPath=file.GetPathName();

m_Path.SetWindowTextW(strPath);

CApplication app;

CWorkbook book;

CWorkbooks books;

if (!app.CreateDispatch(_T("Excel.Application")))

{

MessageBox(_T("Error!Creat Excel Application Server Faile!"));

exit(1);

}

//books.AttachDispatch(app.get_Workbooks(),true);

//book.AttachDispatch(books.Add(_variant_t(strPath)));

books = app.get_Workbooks();

book = books.Add(_variant_t(strPath));

app.put_Visible(true);

//结尾,释放

book.ReleaseDispatch();

books.ReleaseDispatch();

app.ReleaseDispatch();

app.Quit();

}

}

7. 在对话框中添加“写入”按钮,实现新建一Excel文件(存在则覆盖),并向文件中写入数据。实现代码如下。

void CExportToExcelDlg::OnBnClickedButtonWrite()

{

CString strFile = _T("D:\\WriteToExcelTest.xlsx");

COleVariant

covTrue((short)TRUE),

covFalse((short)FALSE),

covOptional((long)DISP_E_PARAMNOTFOUND,   VT_ERROR);

CApplication app;

CWorkbook book;

CWorkbooks books;

CWorksheet sheet;

CWorksheets sheets;

CRange range;

CFont font;

if (!app.CreateDispatch(_T("Excel.Application")))

{

MessageBox(_T("Error!Creat Excel Application Server Faile!"));

}

books = app.get_Workbooks();

//books.AttachDispatch(app.get_Workbooks());可代替上面一行

book = books.Add(covOptional);

//book.AttachDispatch(books.Add(covOptional),true); 可代替上面一行

sheets=book.get_Worksheets();

//sheets.AttachDispatch(book.get_Worksheets(),true); 可代替上面一行

sheet = sheets.get_Item(COleVariant((short)1));

//sheet.AttachDispatch(sheets.get_Item(_variant_t("sheet1")),true); 可代替上面一行

//下面两行,是向A1中写入"Yeah!I can write data to excel!"

range = sheet.get_Range(COleVariant(_T("A1")),COleVariant(_T("A1")));

range.put_Value2(COleVariant(_T("Yeah!I can write data to excel!")));

//下面是向第二行的前十个单元格中输入1到10,十个数字

for(long i=1;i<11;i++)

range.put_Item(_variant_t((long)2),_variant_t((long)i),_variant_t((long)i));

//设置列宽

range = sheet.get_Range(COleVariant(_T("A1")),COleVariant(_T("J1")));

range.put_ColumnWidth(_variant_t((long)5));

//显示表格

app.put_Visible(TRUE);

//保存

book.SaveCopyAs(COleVariant(strFile));

book.put_Saved(true);

//结尾,释放

book.ReleaseDispatch();

books.ReleaseDispatch();

app.ReleaseDispatch();

app.Quit();

}

8. 在对话框中添加列表控件,并关联变量m_Grid,并设置显示为报表样式。在对话框中添加“写入列表”按钮,实现将对话框中已有的表写入到Excel中。实现代码如下。

在初始化函数中,先初始化列表。

//设置列表视图的扩展风格

m_Grid.SetExtendedStyle(LVS_EX_FLATSB//扁平风格显示滚动条

|LVS_EX_FULLROWSELECT//允许整行选中

|LVS_EX_HEADERDRAGDROP//允许整列拖动

|LVS_EX_ONECLICKACTIVATE//单击选中项

|LVS_EX_GRIDLINES);//画出网格线

//设置表头

m_Grid.InsertColumn(0,_T("编号"),LVCFMT_LEFT,100,0);

m_Grid.InsertColumn(1,_T("姓名"),LVCFMT_LEFT,100,1);

m_Grid.InsertColumn(2,_T("所属部门"),LVCFMT_LEFT,100,2);

//向列表中插入数据

int count = 0;

m_Grid.InsertItem(count,_T("001"));

m_Grid.SetItemText(count,1,_T("张一"));

m_Grid.SetItemText(count++,2,_T("销售部"));

m_Grid.InsertItem(count,_T("002"));

m_Grid.SetItemText(count,1,_T("列二"));

m_Grid.SetItemText(count++,2,_T("研发部"));

m_Grid.InsertItem(count,_T("003"));

m_Grid.SetItemText(count,1,_T("宇三"));

m_Grid.SetItemText(count++,2,_T("采购部"));

m_Grid.InsertItem(count,_T("004"));

m_Grid.SetItemText(count,1,_T("宙四"));

m_Grid.SetItemText(count,2,_T("宣传部"));

再编写按钮的响应函数

void CExportToExcelDlg::OnBnClickedButtonWritelist()

{

// TODO: 在此添加控件通知处理程序代码

CString strFile = _T("D:\\WriteListToExcelTest.xlsx");

COleVariant

covTrue((short)TRUE),

covFalse((short)FALSE),

covOptional((long)DISP_E_PARAMNOTFOUND,   VT_ERROR);

CApplication app;

CWorkbook book;

CWorkbooks books;

CWorksheet sheet;

CWorksheets sheets;

CRange range;

if (!app.CreateDispatch(_T("Excel.Application")))

{

MessageBox(_T("Error!Creat Excel Application Server Faile!"));

exit(1);

}

books = app.get_Workbooks();

book = books.Add(covOptional);

sheets = book.get_Worksheets();

sheet = sheets.get_Item(COleVariant((short)1));

//得到全部Cells

range.AttachDispatch(sheet.get_Cells());

CString sText[]={_T("编号"),_T("姓名"),_T("所属部门")};

for (int setnum=0;setnum<m_Grid.GetItemCount()+1;setnum++)

{

for (int num=0;num<3;num++)

{

if (!setnum)

{

range.put_Item(_variant_t((long)(setnum+1)),_variant_t((long)(num+1)),

_variant_t(sText[num]));

}

else

{

range.put_Item(_variant_t((long)(setnum+1)),_variant_t((long)(num+1)),

_variant_t(m_Grid.GetItemText(setnum-1,num)));

}

}

}

//保存

book.SaveCopyAs(COleVariant(strFile));

book.put_Saved(true);

app.put_Visible(true);

//释放对象

range.ReleaseDispatch();

sheet.ReleaseDispatch();

sheets.ReleaseDispatch();

book.ReleaseDispatch();

books.ReleaseDispatch();

app.ReleaseDispatch();

app.Quit();

}

时间: 2024-08-10 14:55:12

EXCEL类型库的添加的相关文章

[转]如何使用MFC和类型库创建自动化项目

本文转自:http://www.cnblogs.com/zhoug2020/archive/2012/04/01/2429064.html 摘要 本文详细介绍了如何自动化像Microsoft Office这样支持COM的应用程序. 更多信息 下面部分介绍了如何创建MFC项目.采用Microsoft Excel举例,你可以将前8个步骤用于任何项目,修改9-15步用于不同的应用程序. 创建自动化项目 1. 在Microsoft Developer Studio中,创建"MFC AppWizard(e

可视化webpart基础开发——利用事件接收器实现同步操作两个文档库(添加、删除、修改文档)

可视化webpart基础开发——利用事件接收器实现同步操作两个文档库(添加.删除.修改文档) 分类: SharePoint2012-01-18 18:02 1189人阅读 评论(0) 收藏 举报 文档propertiesstringurl测试web 1.测试文档库(Doclib1.Doclib2): 增加一栏“测试栏1”. 2.新建“可视化web部件项目”,添加“解决方案资源管理器”里边选中项目右键“添加”-“新建项”-"事件接收器“ 如图操作,选择”列表项事件“和”文档库“集相应处理事件 实现

从tlb,ocx,dll类型库中提取com组件的CLSID

最近在做项目的时候遇到了这个问题. 项目需要动态根据添加com组件,获取组件的某个接口函数.   一般情况下,我们创建com组件的方法是根据它的CLSID号,获得相应的interface,然后通过返回的指针调用相应的接口函数.如下: CoInitialize( NULL ); IpTest* pMask = NULL; HRESULT hr = CoCreateInstance( CLSID_TEST, NULL, CLSCTX_INPROC, IID_ITEST, (LPVOID*)&IpTe

Excel图表中怎样添加参考线,这样操作告别加班

Excel工具在工作中经常会用到,对于一些基本技巧相信大家都是掌握的一看就会,可是如果想要更上一层楼,做一点新花样,就要在学习Excel的路程中多下点功夫.今天要教大家在Excel图表中怎样添加参考线,需要的赶快操作起来. 1 至关重要的参考线 为了让Excel图表有一个直观的认识,往往会添加一条参考线,那如何在Excel图表中添加参考线呢? 在表格中添加辅助列,比如这里我们需要添加一条平均参考线,之后复制平均数据并粘贴到图表中,随后选中图表,右击选择更改数据图表,将辅助列内容更改为折线图即可.

svn,静态库无法添加

“.a”(静态库)文件无法上传(svn工具:Versions) 网上查询了一下,说是Xcode自带的svn和Versions以及一些其它工具都不能上传".a"文件. 解决办法如下: 1.打开终端,输入cd,空格,然后将需要上传的.a文件所在的文件夹(不是.a文件)拖拽到终端(此办法无需输入繁琐的路径,快捷方便) ,回车:2.之后再输入如下命令:svn add libGoogleAnalytics.a,回车:3.之后会出现:A  (bin)  libGoogleAnalytics.a 

Visual Studio 进行Excel相关开发,Microsoft.Office.Interop.Excel.dll库

1. Interop.Excel.dll 的查找 本文中将 Microsoft.Office.Interop.Excel.dll库简称为Interop.Excel.dll库 其实在使用Visual Studio进行Office的Excel开发时,Microsoft.Office.Interop.Excel.dll 可以在类似于下面的目录中找到.并不需要再在网上下载了. E:\Program Files\Microsoft Visual Studio 11.0\Visual Studio Tool

自定义控件如何给特殊类型的属性添加默认值 z(转)

自定义控件如何给特殊类型的属性添加默认值 z 定义控件如何给特殊类型的属性添加默认值了,附自定义GroupBox一枚 标题有点那啥,但确实能表达我掌握此法后的心情. 写自定义控件时往往会有一个需求,就是给属性指定一个默认值(就是可以在VS中右键该属性→重置),如果该属性的类型是内置值类型还好,直接使用DefaultValue特性就好,例如: [DefaultValue(false)] public bool CanSelect { get; set; } 对于能够根据字符串常量转换得到的类型也还

解决 “MoveFile”: 类型库“XXX.dll”中的标识符已经是宏;使用“rename”限定符 类型库符号与系统符号冲突问题

今天在VS工程当中引入一个组件,编译的时候出现警告, “MoveFile”: 类型库“XXX.dll”中的标识符已经是宏:使用“rename”限定符.虽然只是一个警告,但看着实在不爽,更重要的是,警告在某些情况下,可能正是bug的来源,并且这类bug往往非常难以定位.废话不多话,下面来解决问题. 看编译器给出的提示,是告诉我们,类型库当中的符号和系统符号有重名,同时也给出了解决方法,就是使用rename.怎么个rename法呢?其实很简单,我们在导入类型类的时候,直接#import语句后面,通过

自定义控件如何给特殊类型的属性添加默认值 z

定义控件如何给特殊类型的属性添加默认值了,附自定义GroupBox一枚 标题有点那啥,但确实能表达我掌握此法后的心情. 写自定义控件时往往会有一个需求,就是给属性指定一个默认值(就是可以在VS中右键该属性→重置),如果该属性的类型是内置值类型还好,直接使用DefaultValue特性就好,例如: [DefaultValue(false)] public bool CanSelect { get; set; } 对于能够根据字符串常量转换得到的类型也还好,可以这样: [DefaultValue(t