首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >尝试在没有对话框的情况下退出C# Excel工作簿

尝试在没有对话框的情况下退出C# Excel工作簿
EN

Stack Overflow用户
提问于 2013-07-02 05:18:20
回答 2查看 8.3K关注 0票数 9

我正在使用Microsoft Office Interop编辑一些excel文件,当我关闭它们时,我会使用

代码语言:javascript
复制
outputExcelWorkBook.Close(false, paramMissing, paramMissing);

但是,即使我传递了false作为第一个参数,仍然会出现一个对话框。我也尝试过使用true,并给它一个文件路径作为第二个参数,但在两种情况下,都会出现一个对话框,询问我是否要在关闭前保存。有人能告诉我这是怎么回事吗?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2013-07-02 05:24:26

请尝试将Application.DisplayAlerts属性设置为false。对于大多数自动化例程,您可能会发现将此属性设置为false非常有用。记得在返回之前恢复之前的值。

代码语言:javascript
复制
Application applicationInstance = ...;
var oldDisplayAlertsValue = applicationInstance.DisplayAlerts;
applicationInstance.DisplayAlerts = false;
try
{
    outputExcelWorkBook.Close(false, Missing.Value, Missing.Value);
}
finally
{
    appliationInstance.DisplayAlerts = oldDisplayAlertsValue;
}
票数 13
EN

Stack Overflow用户

发布于 2013-07-02 05:43:49

这对我很有效:

  1. Initiate Excel
  2. 打开工作簿
  3. 获取活动工作表并进行编辑(将"Text“添加到单元格2,2)
  4. 使用单个参数true关闭工作簿,这表示”保存更改“
  5. 不显示对话框。

注意:在不带参数的情况下调用Close时,系统会提示我保存更改。

代码语言:javascript
复制
    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();
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/17413887

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档