繁体   English   中英

如何保存工作簿而不显示与 Excel 互操作的保存对话框?

[英]How to save workbook without showing save dialog with Excel interop?

我必须创建一个控制台应用程序,将数据集导出到DataSet 问题是它不应该弹出保存 window,它应该自动创建 Excel 文件。 到目前为止,我有以下代码,但我不知道如何让它自动保存。 将不胜感激任何帮助。

public static void CreateWorkbook(DataSet ds, String path)
{
    int rowindex = 0;
    int columnindex = 0;

    Microsoft.Office.Interop.Excel.Application wapp = new Microsoft.Office.Interop.Excel.Application();
    Microsoft.Office.Interop.Excel.Worksheet wsheet;
    Microsoft.Office.Interop.Excel.Workbook wbook;

    wapp.Visible = false;

    wbook = wapp.Workbooks.Add(true);
    wsheet = (Worksheet)wbook.ActiveSheet;

    try
    {
        for (int i = 0; i < ds.Tables[0].Columns.Count; i++)
        {
            wsheet.Cells[1, i + 1] = ds.Tables[0].Columns[i].ColumnName;

        }

        foreach (DataRow row in ds.Tables[0].Rows)
        {
            rowindex++;
            columnindex = 0;
            foreach (DataColumn col in ds.Tables[0].Columns)
            {
                columnindex++;
                wsheet.Cells[rowindex + 1, columnindex] = row[col.ColumnName];
            }
        }
    }
    catch (Exception ex)
    {
        String err = ex.Message;
    }
    wapp.UserControl = true;
}

所有的 arguments 到WorkBook.SaveAs()都是可选的,但如果你愿意,你可以对大多数使用Type.Missing

典型的调用如下所示:

wbook.SaveAs("c:\\temp\\blah", Microsoft.Office.Interop.Excel.XlFileFormat.xlWorkbookDefault, Type.Missing, Type.Missing,
            false, false, Microsoft.Office.Interop.Excel.XlSaveAsAccessMode.xlNoChange,
            Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing);
wbook.Close();

请注意,我没有包含文件扩展名; Excel 将为您设置。

Workbook.SaveAs 方法 (Microsoft.Office.Tools.Excel) | Microsoft Docs描述了每个 arguments。

ConflictResolution添加到XlSaveConflictResolution.xlLocalSessionChanges
并将应用程序的DisplayAlerts属性设置为false ,这样 window 就不会显示。

m_xlApp.DisplayAlerts = false;

// Quit Excel and clean up.
m_xlWorkbook.SaveAs(Filename: m_xlFilePath, FileFormat: excelFileExtension,
Password: false, ReadOnlyRecommended: XlSaveAsAccessMode.xlNoChange,
ConflictResolution: XlSaveConflictResolution.xlLocalSessionChanges);  

m_xlWorkbook.Close();

请参阅XlSaveConflictResolution 枚举 (Microsoft.Office.Interop.Excel) | Microsoft Docs了解更多信息。

尝试调用工作簿的SaveAs方法。 对于大量参数,尝试将Type.Missing传递给除第一个参数(文件名)之外的所有参数。

wapp.DisplayAlerts = false;

Application.DisplayAlerts属性设置为false将停止显示其所有工作簿的所有警报。

请参阅MSDN 文档

wbook.SaveAs(...);

使用open xml sdk生成文档而不是自动化; 它更可靠。

使用 DisplayAlerts 属性。 它非常简单和快速。

private void SaveAs(Excel.Workbook WorkBook, string FileName)
    {
        m_Saving = true;
        try
        {
            if (Global.CreatingCopy)
                this.ExcelApp.DisplayAlerts = false;

            WorkBook.SaveAs(FileName);
        }
        finally
        {
            m_Saving = false;
            if (this.ExcelApp.DisplayAlerts == false)
                this.ExcelApp.DisplayAlerts = true;
        }
    }

当您要保存文件时,切勿让 Excel 定义文件类型。 因为格式可能会改变。

如果原始文档是.xls 并且当前用户拥有office 2013 默认格式its.xlsx 然后Excel 会将文件转换为.xlsx 并且没有Excel 2010 或上级的用户无法打开该文件。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM