- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
VC 操作 Excel 的方法.doc
VC操作Excel的方法(2007-01-05 21:18:45)
? 分类:VC,VB,Matlab编程开发 A:?classwizard中add class处from type library,去office的安装目录下引入excel.exe(这是office 2003的选择,其他版本都是用olb文件),服务器就算引入了,这时会弹出对话框,要求加入一些类,这些类都是一些接口,里面有大量的方法,类的对象表征着excel文件的一个个部分,常用的有这几个_application,workbooks,_workbook,worksheets,_worksheet,Range,它们分别代表不同的意义._application代表了EXCEL服务器,workbooks表示整个Excel服务器(表现为一个.xls文件)里所有的表,(可以通过新建得到多个表,即MDI程序里的一个视窗一样,所有的视窗就是workbooks), _workbook就是一个表,相当于MDI中的一个视窗, worksheets表示所有的表单,每个表都可能有很多表单(建立一个Excel文件之后,打开,可以看到有sheet1,sheet2等,所有这些sheetn就组成了worksheets), _worksheet就表示一个表单, range表示元素的集合. 搞清楚上面这几个名词的意思非常重要.
B,dlg.h中声明下面几个变量:
_Application exlapp;???//组件服务器的各个classes_Workbook wbk;?Workbooks wbks;?_Worksheet wht;?Worksheets whts;?LPDISPATCH lpDisp;?并在app.cpp的InitInstance方法中加入下面两句AfxInitOle(); AfxEnableControlContainer();
C,Excel文件,而是在开始时就在当前目录下生成了一个Excel文件,在对话框上我设置了两个按钮,下面是显示按钮的代码://创建Excel服务器if(!exlapp.CreateDispatch(Excel.Application))?{??AfxMessageBox(无法启动Excel服务器!);return;?}?COleVariant??avar((long)DISP_E_PARAMNOTFOUND,VT_ERROR);?exlapp.SetVisible(TRUE);//使Excel可见exlapp.SetUserControl(TRUE);//允许其它用户控制Excel,否则Excel将一闪即逝.?//Open an excel file?char path[MAX_PATH];?GetCurrentDirectory(MAX_PATH,path);?CString strPath = path;?strPath += \\VCOpExcel;
?wbks.AttachDispatch(exlapp.GetWorkbooks());??lpDisp=wbks.Open(strPath,牋pavar,avar,avar,avar,avar,avar,avar,avar,avar,avar,avar,avar,avar,avar);??wbks.ReleaseDispatch();?exlapp.ReleaseDispatch();
D,与上面第一种方法一样,可以插入记录:
UpdateData();?????//读入数据if (==m_name)?????//判断名字输入有效{??MessageBox(Please input a right name);??return;?}?if (0=m_age||100=m_age)??//判断年龄输入有效{??MessageBox(Please input a right age);??return;?}
?char *p=strupr(_strdup(m_gener));?if (strcmp(p,FEMALE)strcmp(p,MALE)) //判断性别输入有效{??MessageBox(Please input a right gener);??return;?}?
?Range range;?Range usedRange;?COleVariant??avar((long)DISP_E_PARAMNOTFOUND,VT_ERROR);??if(!exlapp.CreateDispatch(Excel.Application)) //启动服务器{??AfxMessageBox(无法启动Excel
您可能关注的文档
最近下载
- 7.1《短歌行》课件(共56张PPT)2024-2025学年统编版高中语文必修上册.pptx VIP
- 《GB/T 18281.7-2024医疗保健产品灭菌 生物指示物 第7部分:选择、使用和结果判断指南》.pdf
- 微科安装使用说明书调皮%时间.pdf VIP
- HG_T 5171-2017 粒状中微量元素肥料.docx
- 检验检测机构管理评审参考.doc VIP
- 自由体位分娩理论考核试题及答案.docx VIP
- PyQt5入门教程实用知识库分享20240314102955.pdf VIP
- JJF 2182-2024 农灌机井取水量计量监测方法.pdf VIP
- 企业一站式数据开发与治理平台解决方案(35页).pptx VIP
- 新能源汽车检测与维修技术专业人才培养方案.docx VIP
文档评论(0)