前言
用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")
我之前试过后期绑定也可以实现,但是有些功能无法使用