[英]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.