我正在使用Microsoft Office Interop编辑一些excel文件,当我关闭它们时,我会使用
outputExcelWorkBook.Close(false, paramMissing, paramMissing);但是,即使我传递了false作为第一个参数,仍然会出现一个对话框。我也尝试过使用true,并给它一个文件路径作为第二个参数,但在两种情况下,都会出现一个对话框,询问我是否要在关闭前保存。有人能告诉我这是怎么回事吗?
发布于 2013-07-02 05:24:26
请尝试将Application.DisplayAlerts属性设置为false。对于大多数自动化例程,您可能会发现将此属性设置为false非常有用。记得在返回之前恢复之前的值。
Application applicationInstance = ...;
var oldDisplayAlertsValue = applicationInstance.DisplayAlerts;
applicationInstance.DisplayAlerts = false;
try
{
outputExcelWorkBook.Close(false, Missing.Value, Missing.Value);
}
finally
{
appliationInstance.DisplayAlerts = oldDisplayAlertsValue;
}发布于 2013-07-02 05:43:49
这对我很有效:
注意:在不带参数的情况下调用Close时,系统会提示我保存更改。
Microsoft.Office.Interop.Excel.Application excel = new Application();
Microsoft.Office.Interop.Excel.Workbook workBook =
excel.Workbooks.Open(fileLocation);
Microsoft.Office.Interop.Excel.Worksheet sheet = workBook.ActiveSheet;
sheet.Cells[2, 2] = "Text";
workBook.Close(true);
excel.Quit();https://stackoverflow.com/questions/17413887
复制相似问题