C# Excel 互操作合并不起作用

Posted

技术标签:

【中文标题】C# Excel 互操作合并不起作用【英文标题】:C# Excel interop merge not working 【发布时间】:2017-02-11 04:56:33 【问题描述】:

我已经定义了一个范围:

Range range =  ws.Range[ws.Cells[7, 1], ws.Cells[7, 4]];

并用

检查
range.Interior.Color = rgbBlueViolet;

所以范围是正确的,因为我看到它是彩色的。

但是当我这样做时

range.Merge(true);

我得到以下异常:

System.Runtime.InteropServices.COMException (0x800A03EC):来自 HRESULT 的异常:0x800A03EC 在 System.RuntimeType.ForwardCallToInvokeMember(字符串成员名称、BindingFlags 标志、对象目标、Int32 [] aWrapperTypes、MessageData 和 msgData) 在 Microsoft.Office.Interop.Excel.Range.Merge(跨对象)

我无法理解。

我的目标是将前 4 列合并在一起,这在我看来是合法的。

感谢您的帮助 帕特里克

【问题讨论】:

您可以尝试从 Excel 手动合并范围以查看错误是什么,或者可能是 range.Merge(false);。在少数情况下不允许合并。 唉,没有。手动完美运行。 【参考方案1】:

好的,问题是必须首先选择要合并的范围。要做到这一点,工作表不能被最小化。因此代码是:

Application app = new Application();
app.Visible = false;
app.WindowState = XlWindowState.xlNormal; <---not minimized   
...
Range r = ws.Range[ws.Cells[row + 7, 1], ws.Cells[row + 7, 5]];
r.Select(); <-----necessary
r.Merge(false);

【讨论】:

一千谢谢!!!这在 Windows 10、Excel 2016 上发生在我身上,这修复了它。奇怪的是,它在某些计算机上最小化窗口但在其他计算机上运行良好。 Windows 变得太快/太智能了。 更多关于 HRESULT 中“糟糕的异常”的信息:0x800A03EC ***.com/a/20424879/2559297 我也不需要选择;只需设置 app.WindowState = XlWindowState.xlNormal

以上是关于C# Excel 互操作合并不起作用的主要内容,如果未能解决你的问题,请参考以下文章

C# COM-Interop dll for C++ COM dll 在 2 个解决方案之间不起作用

Excel VBA UDF 操作字符串不起作用

熊猫合并索引不起作用

excel条件格式不起作用?

导出到 CSV/Excel 功能在 Datatable 中不起作用?

C# WEB API CORS 不起作用