作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在 .NET 应用程序(WPF,如果重要的话)中创建 Microsoft Excel 的实例,并将其嵌入其中,如下所示:
var excelType = Type.GetTypeFromProgID("Excel.Application");
var excelObj = Activator.CreateInstance(excelType);
excelType.InvokeMember("Visible", BindingFlags.SetProperty, null, excelObj, new object[] { true }, ComCulture);
var excelHwnd = new IntPtr((int)excelType.InvokeMember("Hwnd", BindingFlags.GetProperty, null, excelObj, new object[0], ComCulture));
var managedWindowHwnd = new WindowInteropHelper(Application.Current.MainWindow).Handle;
SetParent(excelHwnd, managedWindowHwnd);
MoveWindow(excelHwnd, 0, 0, Convert.ToInt32(Width), Convert.ToInt32(Height), true);
除 Excel 之外的所有工作都不会加载已安装的加载项。如果我通过开始菜单运行 Excel,它会加载加载项。
我想我需要向 Excel 指定一些参数才能启用加载项加载。但我不知道什么/如何...
最佳答案
您可以使用互操作手动执行此操作,您可以引用我的帖子 Get the excel cell address from a UDF获取 Excel 的 Application 对象的句柄。拥有应用程序后,您可以通过循环 application.AddIns 和 application.ComAddIns 并将每个项目的安装/连接属性设置为 true 来手动启用插件
关于.net - 以编程方式创建 Excel 实例并加载所有加载项,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10312511/
我是一名优秀的程序员,十分优秀!