在WINFORM里打开EXCEL文件

本文详细介绍了如何在WINFORM框架下利用OLE技术嵌入并操作EXCEL文件,通过事件绑定和COM组件引用实现了浏览器容器内EXCEL文件的无缝集成。关键在于正确设置文件打开方式及调用Excel对象属性进行数据迁移。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最近有个项目需要在WINFORM框架下嵌入EXCEL文件,因为考虑到浏览器支持这个功能那么具体数据迁移就不许要自己做了。所以打算使用OLE空间WEBBROWSER,代码如下:首先需要引用几个COM组件,Internet Explorer组件,事件绑定代码:            reportsManagerForm.axWebBrowser1.DocumentComplete += new AxSHDocVw.DWebBrowserEvents2_DocumentCompleteEventHandler(axWebBrowser1_DocumentComplete);

事件代码:     

            Object o = e.pDisp;

            Object oDocument = o.GetType().InvokeMember("Document", BindingFlags.GetProperty, null, o, null);

            Object oApplication = o.GetType().InvokeMember("Application", BindingFlags.GetProperty, null, oDocument, null);

            //Object oName = o.GetType().InvokeMember("Name",BindingFlags.GetProperty ,null,oApplication,null);

            //由于打开的是excel文件,所以这里的oApplication 其实就是Excel.Application

            Microsoft.Office.Interop.Excel.Application eApp = (Microsoft.Office.Interop.Excel.Application)oApplication;//这样就可以象上文中所述来操作Excel了。

打开EXCEL代码: reportsManagerForm.axWebBrowser1.Navigate(fileFullPath);
结果是能打开,但不能嵌入到IE容器里,原因是文件打开方式有问题,在文件夹选项,选择文件类型,选择EXCEL文档格式,点击高级,选择在“同一个窗口打开”。代码实现:SOFTWARE/Classes/Excel.Sheet.8 的BrowserFlags设置为1
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值