首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >如何使用后期绑定来获取excel实例?

如何使用后期绑定来获取excel实例?
EN

Stack Overflow用户
提问于 2009-04-22 21:42:03
回答 3查看 12.4K关注 0票数 18

我正在使用

代码语言:javascript
复制
[DllImport("Oleacc.dll")]
static extern int AccessibleObjectFromWindow(
int hwnd, 
uint dwObjectID, 
byte[] riid,
ref Excel.Window ptr);

使用他的句柄获取Excel实例,这个句柄是从excel实例的进程ID中获得的。

下面是我使用这些函数时的样子

代码语言:javascript
复制
const uint OBJID_NATIVEOM = 0xFFFFFFF0;
Guid IID_IDispatch = new Guid("{00020400-0000-0000-C000-000000000046}");
Excel.Window ptr = null;  
int hr = AccessibleObjectFromWindow(hwndChild, OBJID_NATIVEOM, 
          IID_IDispatch.ToByteArray(), ref ptr);

Object objApp = ptr.Application;

这种简单的代码效果很好,但唯一的问题是我必须添加对Office2003主互操作程序集的引用。

正如您所看到的,函数中的最后一个参数是我需要添加对Pias的引用的原因,所以我的问题是,是否有一种方法可以避免使用Interop Assemblies,我已经尝试了延迟绑定,但可能我一直在做错误的事情,因为我无法使其工作。

EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/779363

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档