1 回答

TA貢獻1825條經驗 獲得超6個贊
雖然我無法使用現有方法傳入多個變量,但我找到了一種執行宏的替代方法,該方法允許我根據需要傳遞參數。
public void runTemplate(string templateName, string sourceFile, string destinationFile, string ITPath, string date)
{
string sDate = date;
Microsoft.Office.Interop.Excel.Application ExcelApp = new Microsoft.Office.Interop.Excel.Application();
ExcelApp.DisplayAlerts = false;
object misValue = System.Reflection.Missing.Value;
ExcelApp.Visible = false;
Microsoft.Office.Interop.Excel.Workbook ExcelWorkBook = ExcelApp.Workbooks.Open(sourceFile);
ExcelApp.Run("DoTheImport", sDate);
ExcelWorkBook.SaveCopyAs(destinationFile);
ExcelWorkBook.SaveCopyAs(ITPath);
ExcelWorkBook.Close(false, misValue, misValue);
ExcelApp.Quit();
if (ExcelWorkBook != null) { System.Runtime.InteropServices.Marshal.ReleaseComObject(ExcelWorkBook); }
if (ExcelApp != null) { System.Runtime.InteropServices.Marshal.ReleaseComObject(ExcelApp); }
}
我已經刪除了 RunMacro 方法,只是用來ExcelApp.Run("DoTheImport", sDate);執行宏。這個方法允許我將參數傳遞到宏中,可以通過添加'ByVal'參數傳遞機制在宏中訪問:
Sub DoTheImport(ByVal sDate As String)
- 1 回答
- 0 關注
- 353 瀏覽
添加回答
舉報