web-dev-qa-db-ja.com

C#を使用してDataSetから複数のシートでExcelファイルを作成する方法

C#を使用してDataSetから複数のシートでExcelファイルを作成する方法。 1枚のExcelファイルを作成できました。しかし、私は複数のシートに対してそれを行うことはできません。

よろしく

9
HarshJain

これは、プログラムでExcelワークブックを作成して2つのシートを追加し、両方のシートにデータを入力する単純なC#クラスです。最後に、ワークブックをアプリケーションのルートディレクトリ内のファイルに保存して、結果を確認できるようにします...

public class Tyburn1
{
    object missing = Type.Missing;
    public Tyburn1()
    {
        Excel.Application oXL = new Excel.Application();
        oXL.Visible = false;
        Excel.Workbook oWB = oXL.Workbooks.Add(missing);
        Excel.Worksheet oSheet = oWB.ActiveSheet as Excel.Worksheet;
        oSheet.Name = "The first sheet";
        oSheet.Cells[1, 1] = "Something";
        Excel.Worksheet oSheet2 = oWB.Sheets.Add(missing, missing, 1, missing) 
                        as Excel.Worksheet;
        oSheet2.Name = "The second sheet";
        oSheet2.Cells[1, 1] = "Something completely different";
        string fileName = Path.GetDirectoryName(Assembly.GetExecutingAssembly().Location)        
                                + "\\SoSample.xlsx";
        oWB.SaveAs(fileName, Excel.XlFileFormat.xlOpenXMLWorkbook,
            missing, missing, missing, missing,
            Excel.XlSaveAsAccessMode.xlNoChange,
            missing, missing, missing, missing, missing);
        oWB.Close(missing, missing, missing);
        oXL.UserControl = true;
        oXL.Quit();
    }
}

これを行うには、Microsoft.Office.Interop.Excelへの参照をプロジェクトに追加する必要があります(1つのシートを作成しているので、すでにこれを行っている可能性があります)。

2番目のシートを追加するステートメントは...

Excel.Worksheet oSheet2 = oWB.Sheets.Add(missing, missing, 1, missing) 
                            as Excel.Worksheet;

'1'引数は単一のシートを指定し、一度に複数のシートを追加する場合はさらに多くなる可能性があります。

最後の注意:ステートメントoXL.Visible = false; Excelにサイレントモードで起動するように指示します。

16
Gayot Fow
var groupedSheetList = UserData
    .GroupBy (u => u.date)
    .Select (grp => grp.ToList ())
    .ToList ();

あなたはこれを試すことができます

using (var package = new ExcelPackage ()) 
    {
        foreach (var item in groupedSheetList) {
            var workSheet = package.Workbook.Worksheets.Add (item[0].date);
    }
}
0
Deepika chalana