我通过C#程序和OLE刷新Excel 2007数据连接。大多数工作都是由一个Workbooks.RefreshAll()语句完成的。
正如刷新电子表格的本质一样,各种各样的事情都可能出错。在刷新过程中,程序可以提供有关“无法从文件中读取数据'|'的对话框错误消息,以及有关”重叠数据透视表报告“的消息。这两个都是致命的,我应该能够捕获这些错误,并在出错时退出我的程序。
不幸的是,我似乎无法捕捉到这些问题,而是我的自动程序一直存在,直到我出现并点击对话框进入。
有没有人知道是否可以以编程方式捕获excel对话框中显示的错误,而不是将它们显示给用户?
答案 0 :(得分:9)
最好的办法是将Application.DisplayAlerts属性设置为False。也就是说,假设您的Excel.Application对象变量名为“xlApp”,您只需执行以下操作:
xlApp.DisplayAlerts = false;
请注意,这将导致每个对话框都采用默认响应,这通常是您想要的。 (没有好办法解决这个问题。让DisplayAlerts = True并使用SendKeys可能是你唯一的另一种选择,但会很丑陋并且非常容易出错。)
由于您是通过OLE自动化进行此调用,因此此调用是跨进程的,因此,DisplayAlerts设置将一直存在,直到您更改它为止。 (如果在进程中调用,通过VBA,它会在例程完成时自动切换回true。相同的行为可能适用于通过CommandBar或Ribbon控件调用的VB.NET或C#加载项,但是需要测试以确定。)