Windows 8 中的 Excel 版本 15 (2013)。
重现步骤:
- 以编程方式打开 Excel 和 XLA 文件。
- 确保没有打开其他工作簿。
- 设置 Excel.Application.Visible = True
Excel 对象被破坏并在随后的 COM 消息中产生错误。
如果除了 XLA 之外还有一个打开的工作簿,那么一切正常。但如果 XLA 是唯一打开的书,它就失败了。
问题:只是我,或者这是一个 COM Excel 服务器错误?
Windows 8 中的 Excel 版本 15 (2013)。
重现步骤:
Excel 对象被破坏并在随后的 COM 消息中产生错误。
如果除了 XLA 之外还有一个打开的工作簿,那么一切正常。但如果 XLA 是唯一打开的书,它就失败了。
问题:只是我,或者这是一个 COM Excel 服务器错误?
看起来 Excel GUI 和该版本中引入的 Excel COM 服务器之间存在偏差。
在旧版本中,当最后一个工作簿关闭时,服务器和 GUI 的行为方式相同:一个空的 GUI(即,上面没有工作簿)仍然可见,前提是它在关闭最后一个工作簿之前可见。
但是,这种行为在版本 15(或更高版本)中发生了变化,现在当您关闭最后一本书时 GUI 会隐藏,而服务器则不会。这导致如果您的 COM 客户端在 GUI 可见时关闭最后一个工作簿,服务器不会将其变为不可见状态,因此它将以某种方式获得不兼容的状态,这是无法从 GUI 访问的。
当 Excel 的 GUI 发生变化时,似乎已经引入了这个问题,因为它现在为每个工作簿分配了一个独立的窗口。
因此,解决方案是让客户端确保在关闭最后打开的书时使 GUI 不可见。
如果您加载了加载项,此问题似乎会更加严重。也许发生的事情是插件(这是我的猜测)与某个隐藏窗口相关联,现在客户必须解决的问题涉及最后一本书的窗口(现在关闭)和与插件相关联的窗口-在。