簡體   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