欢迎来到冰豆网! | 帮助中心 分享价值,成长自我!
冰豆网
全部分类
  • IT计算机>
  • 经管营销>
  • 医药卫生>
  • 自然科学>
  • 农林牧渔>
  • 人文社科>
  • 工程科技>
  • PPT模板>
  • 求职职场>
  • 解决方案>
  • 总结汇报>
  • 党团工作>
  • ImageVerifierCode 换一换
    首页 冰豆网 > 资源分类 > DOCX文档下载
    分享到微信 分享到微博 分享到QQ空间

    VC操作Excel的方法技巧解答.docx

    • 资源ID:9097693       资源大小:47.29KB        全文页数:16页
    • 资源格式: DOCX        下载积分:3金币
    快捷下载 游客一键下载
    账号登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录 QQ登录
    二维码
    微信扫一扫登录
    下载资源需要3金币
    邮箱/手机:
    温馨提示:
    快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP,免费下载
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    VC操作Excel的方法技巧解答.docx

    1、VC操作Excel的方法技巧解答Abstract: Based on the comprehensive analysis on the plastic parts structure service requirement, mounding quality and mould menu factoring cost. A corresponding injection mould of internal side core pulling was designed. By adopting the multi-direction and multi-combination core-pul

    2、ling. A corresponding injection mould of internal side core pulling was designed, the working process of the mould was introducedVC操作Excel的方法(2007-01-05 21:18:45) 分类:VC,VB,Matlab编程开发A:从classwizard中add class处from type library,去office的安装目录下引入excel.exe(这是office 2003的选择,其他版本都是用olb文件),服务器就算引入了,这时会弹出对话框,要

    3、求加入一些类,这些类都是一些接口,里面有大量的方法,类的对象表征着excel文件的一个个部分,常用的有这几个_application,workbooks,_workbook,worksheets,_worksheet,Range,它们分别代表不同的意义._application代表了EXCEL服务器,workbooks表示整个Excel服务器(表现为一个.xls文件)里所有的表,(可以通过新建得到多个表,即MDI程序里的一个视窗一样,所有的视窗就是workbooks), _workbook就是一个表,相当于MDI中的一个视窗, worksheets表示所有的表单,每个表都可能有很多表单(建立一

    4、个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(); AfxEnableCo

    5、ntrolContainer();C,这里我没有像上面一样完全用程序来生成一个Excel文件,而是在开始时就在当前目录下生成了一个Excel文件,在对话框上我设置了两个按钮,下面是显示按钮的代码:/创建Excel服务器if(!exlapp.CreateDispatch(Excel.Application)AfxMessageBox(无法启动Excel服务器!);return;COleVariantavar(long)DISP_E_PARAMNOTFOUND,VT_ERROR);exlapp.SetVisible(TRUE);/使Excel可见exlapp.SetUserControl(TRUE

    6、);/允许其它用户控制Excel,否则Excel将一闪即逝./Open an excel filechar pathMAX_PATH;GetCurrentDirectory(MAX_PATH,path);CString strPath = path;strPath += VCOpExcel;wbks.AttachDispatch(exlapp.GetWorkbooks();lpDisp=wbks.Open(strPath,avar,avar,avar,avar,avar,avar,avar,avar,avar,avar,avar,avar,avar,avar);wbks.ReleaseDisp

    7、atch();exlapp.ReleaseDispatch();D,与上面第一种方法一样,可以插入记录:UpdateData();/读入数据if (=m_name)/判断名字输入有效MessageBox(Please input a right name);return;if (0=m_age|100对组件得先进行初始化COM在.app文件的InitInstance()函数加入AfxOleInit();或if(CoInitialize(NULL)!=0)AfxMessageBox(初始化COM支持库失败!);exit(1);VC中操作excel表格 收藏 摘要:使用Microsoft Offi

    8、ce所带的控件来实现代码操作excel表格。操作系统是Microsoft XP,办公套装是Microsoft Office 2003,编程环境是Microsoft Visual Studio 6.0,一切都是Microsoft。我最近要将数据库中的内容查询出来放到excel表格以便打印,所以上网找了这方面的内容,这里主要是抛砖引玉。从思路上来看,操作excel表格就是将其打开,然后写入/读出数据,然后关闭。首先创建一个程序(我的例子是一个MFC的单文档程序),在程序的入口处和出口处先作这样两个步骤来支持COM库:在程序入口处CXXXApp: InitInstance()函数AfxEnableC

    9、ontrolContainer();语句之后加入下面几行:if (CoInitialize(NULL) != 0) AfxMessageBox(“初始化COM支持库失败!”); exit(1);假如这个条件不通过就不能运行起程序。在程序的出口处CXXXApp: ExitInstance()函数return语句之前加入下面这句话:CoUninitialize();来释放COM支持库。这样对COM支持库的代码已经完成。下面要从Office的安装目录中找到对VC操作excel文件的动态库,在某些版本下这个文件是Excel8.olb或者Excel9.olb,在我的版本中是excel.exe这个exe也

    10、是动态库的形式,是微软公司主要的文件结果之一。选择vc的View菜单里面的ClassWizad命令,会弹出一个对话框;然后点击Add Class按钮选择From a type library,会弹出一个打开对话框,从这里打开Office安装目录下Office11EXCEL.EXE文件,从里面选择几个要用到的类:_Application, Workbooks, _Wrokbook, Worksheets, _WorkSheet, Range,点击OK按钮。会在程序中生成一个excel.h和excel.cpp文件,这些文件中包含了刚才我们选择的几个类的代码。下面介绍一下这几个类:在vc操纵exce

    11、l的exe动态库里面有好多个对象模型,就是刚才在创建过程中看到的那个列表,但是经常用到的有这么几个:_Application, Workbooks, _Wrokbook, Worksheets, _WorkSheet, Range,Charts和_Chart,最后面的两个是用来操作图表的,我没有用到所以这里也就不记录了。_Application:这里的Application就是Excel本身,众所周知,一个Excel可以包含多个工作簿,每个工作簿又可以包含多个工作表,而每个工作表又可以包含多个区域或者图表,所以这里他们是树型的结构关系,而application最基本的一个功能就是找到它的子项工

    12、作簿。果然,我们在引入我们程序的Application类中看到了这样的成员函数:GetWorkbooks()。既然application就是excel,那么打开程序,退出程序,显示/隐藏程序这些基本的操作都可以在这个类的成员函数中找到,果不其然。Workbooks:这个对象是一个容器对象,它里面存放着所有打开的工作簿。因此,我们可以猜测它一定有添加,查找,打开/关闭工作簿的功能。(本程序中使用excel的一个xlt模板来生成一个xls文件就是使用了这个容器对象的添加功能。)_Workbook:这是一个工作簿,也就相当于一个xls文件。Excel可以同时打开多个工作簿,所以工作簿之间必定能够互相

    13、切换,每个工作簿可以关联工作表容器并获得工作表的索引。Worksheets:也是一个容器对象,和Workbooks类似。_Worksheet:这个就是我们看到的工作表,比如Sheet1,sheet2等等。Rang:就是我们看到的能选中的方框的大小。而我们所要作的操作基本上是以区域为单位进行的。介绍完这些,就添加一个菜单,来响应操作excel的命令。然后下面附带这个函数的内容,注释还算可以吧,并且附上网上不知道谁写的但是转载极多的一个封装类。view plaincopy to clipboardprint?1. _Application_app; 2. _Workbook_workBook; 3

    14、. _Worksheet_workSheet; 4. WorksheetsworkSheets; 5. WorkbooksworkBooks; 6. Rangerange; 7. RangecopyFrom; 8. RangecopyTo; 9. 10. if(!_app.CreateDispatch(Excel.Application,NULL) 11. 12. MessageBox(创建Excel服务失败!,信息提示,MB_OK); 13. return; 14. 15. /利用模板建立新文档 16. workBooks.AttachDispatch(_app.GetWorkbooks()

    15、; 17. _workBook.AttachDispatch(workBooks.Add(_variant_t(C:DocumentsandSettings模板.xlt);/你可以自己创建一个模板,并自由设定目录 18. /得到worksheets 19. workSheets.AttachDispatch(_workBook.GetWorksheets(); 20. /得到workSheet 21. _workSheet.AttachDispatch(workSheets.GetItem(_variant_t(sheet1); 22. /得到拷贝的母板 23. copyFrom.Attach

    16、Dispatch(_workSheet.GetRange(_variant_t(A3),_variant_t(Q6); 24. copyTo.AttachDispatch(_workSheet.GetRange(_variant_t(A61),_variant_t(A61); 25. /得到全部的cells 26. range.AttachDispatch(_workSheet.GetCells(); 27. 28. / 29. /上边是头 30. 31. /* 32. 中间要做的工作有这两项:设置数据和拷贝格式 33. 设置数据就是将数据库中查询出来的数据写入表格,拷贝格式就是将表格拷贝到别

    17、的地方。 34. */35. /写入数据 36. range.SetItem(_variant_t(long)3),_variant_t(long)1),_variant_t(写入数据了); 37. range.SetItem(_variant_t(long)5),_variant_t(long)1),_variant_t(重新写入数据了); 38. /拷贝一段区域到另外的一段区域 39. copyFrom.Copy(_variant_t(copyTo); 40. range.SetItem(_variant_t(long)61),_variant_t(long)1),_variant_t(1

    18、23); 41. 42. /显示excel表格 43. _app.SetVisible(TRUE); 44. /保存为文件 45. _app.SetDisplayAlerts(FALSE);/隐藏弹出的对话框 46. _workSheet.SaveAs(d:Test.xls,vtMissing,vtMissing,vtMissing,vtMissing, 47. vtMissing,vtMissing,vtMissing,vtMissing,vtMissing); 48. _app.Quit(); 49. /下边是尾 50. / 51. copyFrom.ReleaseDispatch();

    19、52. copyTo.ReleaseDispatch(); 53. range.ReleaseDispatch(); 54. _workSheet.ReleaseDispatch(); 55. workSheets.ReleaseDispatch(); 56. _workBook.ReleaseDispatch(); 57. workSheets.ReleaseDispatch(); 58. _app.ReleaseDispatch();别人的代码:view plaincopy to clipboardprint?1. .h文件: 2. #includecomdef.h 3. #include

    20、excel.h 4. classExcelFile 5. 6. public: 7. voidShowInExcel(boolbShow); 8. CStringGetCell(intiRow,intiColumn); 9. intGetCellInt(intiRow,intiColumn); 10. intGetRowCount(); 11. intGetColumnCount(); 12. boolLoadSheet(intiIndex); 13. CStringGetSheetName(intiIndex); 14. staticvoidInitExcel(); 15. staticvo

    21、idReleaseExcel(); 16. intGetSheetCount(); 17. boolOpen(CStringFileName); 18. ExcelFile(); 19. virtualExcelFile(); 20. protected: 21. private: 22. static_Applicationm_ExcelApp; 23. 24. Workbooksm_Books; 25. _Workbookm_Book; 26. Worksheetsm_sheets; 27. _Worksheetm_sheet; 28. Rangem_Rge; 29. ; 30. .cpp

    22、文件: 31. ExcelFile:ExcelFile() 32. 33. 34. ExcelFile:ExcelFile() 35. 36. m_Rge.ReleaseDispatch(); 37. m_sheet.ReleaseDispatch(); 38. m_sheets.ReleaseDispatch(); 39. m_Book.ReleaseDispatch(); 40. m_Books.ReleaseDispatch(); 41. 42. voidExcelFile:InitExcel() 43. 44. /创建Excel2000服务器(启动Excel) 45. if(!m_Ex

    23、celApp.CreateDispatch(Excel.Application,NULL) 46. 47. AfxMessageBox(创建Excel服务失败!); 48. exit(1); 49. 50. 51. voidExcelFile:ReleaseExcel() 52. 53. m_ExcelApp.ReleaseDispatch(); 54. 55. boolExcelFile:Open(CStringFileName) 56. 57. /打开excel文件 58. /利用模板文件建立新文档 59. m_Books.AttachDispatch(m_ExcelApp.GetWorkbooks(),true); 60. LPDISPATCHlpDis=NULL; 61. lpDis=m_Books.Add(_variant_t(FileName);/如何判断文件是否打开? 62. if(lpDis) 63


    注意事项

    本文(VC操作Excel的方法技巧解答.docx)为本站会员主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

    copyright@ 2008-2022 冰点文档网站版权所有

    经营许可证编号:鄂ICP备2022015515号-1

    收起
    展开