我已经搜索过,但我发现没有任何内容直接符合我要查找的内容(或者也许我的搜索没有符合单词组合)。
在 C# 中,我使用 Interop.Excel 创建了一个 Excel 工作表,在其中插入一些数据并创建一个图表。当我执行 xlWorkBook.SaveAs 时,这一切都工作正常。
我想要做的是提示用户将自动化工作簿放在具有自己的文件名的位置。我努力了 (http://p2p.wrox.com/vb-how/63900-disabling-second-excel-save-prompt.html http://p2p.wrox.com/vb-how/63900-disabling-second-excel-save-prompt.html),他基本上执行一个新的 SaveFileDialog,然后如果它 == OK,他会构建他的 Excel 工作表,然后他说他的 workbook.SaveAs(FilePathFromSaveAsDialog) 会导致提示。当我尝试时,出现“当应用程序未在 UserInteractive 模式下运行时显示模式对话框不是有效操作”错误。
我会粘贴我的所有代码,但它位于一个单独的系统上,但其目的是:
using Excel = Microsoft.Office.Interop.Office
//....then on click of link button....
Excel.Application xlApp;
Excel.Workbook xlWorbook;
Excel.Workbooks xlWorkbooks;
Excel.Sheets xlSheets;
Excel.Worksheet xlWorkSheet;
object misValue = System.Reflection.Missing.Value;
xlApp = new Excel.ApplicationClass();
xlWorkBooks = xlApp.Workbooks;
xlWorkBook = xlWorbooks.Add(misValue);
xlSheets = xlWorkBook.Worksheets;
xlWorkSheet = (Excel.Worksheet)xlSheets.get_Item(1);
//....Now I fill my Excel sheet data and make my chart >>> then I close like below...
xlApp.DisplayAlerts = true;
//HERE IS WHERE I WANT TO EITHER PASS THE PATH AND FILE NAME FROM USER OR USE A PROMPT
xlWorkBook.SaveAs("Test.xls", Excel.XFileFormat.XlWorkbookNormal, misValue, misValue, misValue, misValue, Excel.XlSaveAsAccessMode.xlExclusive, misValue, misValue, misValue, misValue, misValue);
xlWorkBook.Close(true, misValue, misValue);
xlApp.Quit();
//finally I release all my objects via Marshal.ReleaseComObject then GC.Collect