在vb.net下如何操作已经打开的活动excel文件

在vb.net下如何操作已经打开的活动excel文件


前言

用VB.NET操作excel的时候发现,如果用new Microsoft.Office.Interop.Excel.Application 这种方法无法操作已经打开的excel工作簿,所以找了很久都没有找到办法.后来在QQ群大佬的指点下终于找到了解决办法,代码如下


提示:以下是本篇文章正文内容,下面案例可供参考

一、原理是什么

在两个不同的实体(两个线程或者进程甚至机器、在Managed和Unmanaged之间、托管和非托管之间)进行方法调用和参数传递的时候,具体的调用方法和参数的内存格式可能需要一定的转换,这个转换的过程叫做Marshal。

Marshal就是把一个结构(类)序列化成一段内存,然后送到另一个进程(.net中Application domain)中供另一个进程中的函数使用。
比如你的一个结构
我理解的就是通过Marshal能够把一些进程给送到我们现在使用 的Excel.Application 中来

二、使用步骤

1.引入库

代码如下(示例):

Imports System.Runtime.InteropServices

2.读入数据

代码如下(示例):

Dim myexcel As Microsoft.Office.Interop.Excel.Application
myexcel = Marshal.GetActiveObject("excel.Application")

我之前试过后期绑定也可以实现,但是有些功能无法使用


总结

使用后发现Marshal.GetactiveObject 很智能,能判断是否存在需要转化的活动窗口是否存在,如果不存在能够直接生成一个新的,不需要我们再去判断了
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值