2

こんにちは、すべて Microsoft Office 相互運用機能を使用して Excel を作成しています。ファイルは正常に作成されます。しかし、問題は、ファイルを作成するときに、Excel を開くだけで値が Excel に追加され、指定された名前で保存されることです。時間の結果は例外につながります.データベースから多くの行を含む約75個のファイルを作成しているため、時間がかかります.Excelに入力すると例外が作成されるため、処理中にタスクを実行できません.プロセスを実行する方法はありますかバックグラウンドで、ファイル作成ごとに Excel アプリケーションが開かないようにします。

Excel.Application oXL;
Excel.Workbook oWB;
Excel.Worksheet oSheet;
Excel.Range oRange;

// Start Excel and get Application object. 
oXL = new Excel.Application();

// Set some properties 
oXL.Visible = true;
oXL.DisplayAlerts = false;

// Get a new workbook. 
oWB = oXL.Workbooks.Add(Missing.Value);

// Get the active sheet 
oSheet = (Excel.Worksheet)oWB.ActiveSheet;
oSheet.Name = "Sales";

// Process the DataTable 
// BE SURE TO CHANGE THIS LINE TO USE *YOUR* DATATABLE 
DataTable dt = dtt;

int rowCount = 1;
foreach (DataRow dr in dt.Rows)
{
    rowCount += 1;
    for (int i = 1; i < dt.Columns.Count + 1; i++)
    {
        // Add the header the first time through 
        if (rowCount == 2)
        {
            oSheet.Cells[1, i] = dt.Columns[i - 1].ColumnName;
        }
        oSheet.Cells[rowCount, i] = dr[i - 1].ToString();
    }
}

// Resize the columns 
//oRange = oSheet.get_Range(oSheet.Cells[1, 1],
//              oSheet.Cells[rowCount, dt.Columns.Count]);


oRange = oSheet.Range[oSheet.Cells[1, 1], oSheet.Cells[rowCount, dt.Columns.Count]];
oRange.EntireColumn.AutoFit();

// Save the sheet and close 
// oSheet = null;
oRange = null;

oWB.SaveAs("" + username + " .xls", Excel.XlFileFormat.xlWorkbookNormal,
    Missing.Value, Missing.Value, Missing.Value, Missing.Value,
    Excel.XlSaveAsAccessMode.xlExclusive,
    Missing.Value, Missing.Value, Missing.Value,
    Missing.Value, Missing.Value);
oWB.Close(Missing.Value, Missing.Value, Missing.Value);
oWB = null;
oXL.Quit();

// Clean up 
// NOTE: When in release mode, this does the trick 
GC.WaitForPendingFinalizers();
GC.Collect();
GC.WaitForPendingFinalizers();
GC.Collect();
4

2 に答える 2

5

デフォルトでは、相互運用機能を介した Excel は非表示として開きます。
Excel の可視性を変更するのはコードです。線を取り除く

oXL.Visible = true;

またはfalseに設定

oXL.Visible = false;
于 2012-06-12T07:57:04.897 に答える
4

これを試して...

// Excel を起動し、Application オブジェクトを取得します。oXL = 新しい Excel.Application { Visible = false };

  • または - // いくつかのプロパティを設定します oXL.Visible = false ;
于 2012-06-12T07:41:20.727 に答える