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

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

  • 前言
  • 一、原理是什么
  • 二、使用步骤
    • 1.引入库
    • 2.读入数据
  • 总结


前言

用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 很智能,能判断是否存在需要转化的活动窗口是否存在,如果不存在能够直接生成一个新的,不需要我们再去判断了

你可能感兴趣的:(vb.net,vb.net,excel,编程语言)