Eksportuj tabelę danych do programu Excel za pomocą Open Xml SDK w c #

Przepraszam za mój angielski proszę. Jestem nowy w open xml sdk. Mój program ma możliwość eksportowania niektórych danych i DataTable do pliku Excel (szablon) W szablonie wstawiam dane do niektórych symboli zastępczych. To działa bardzo dobrze, ale muszę też wstawić DataTable ... Mój przykładowy kod:

using (Stream OutStream = new MemoryStream())
{
    // read teamplate
    using (var fileStream = File.OpenRead(templatePath))
        fileStream.CopyTo(OutStream);

    // exporting
    Exporting(OutStream);

    // to start
    OutStream.Seek(0L, SeekOrigin.Begin);

    // out
    using (var resultFile = File.Create(resultPath))
        OutStream.CopyTo(resultFile);

Następna metoda eksportowania

private void Exporting(Stream template)
{
    using (var workbook = SpreadsheetDocument.Open(template, true, new OpenSettings                          { AutoSave = true }))
    {
        // Replace shared strings
        SharedStringTablePart sharedStringsPart = workbook.WorkbookPart.SharedStringTablePart;
        IEnumerable<Text> sharedStringTextElements = sharedStringsPart.SharedStringTable.Descendants<Text>();

        DoReplace(sharedStringTextElements);
        // Replace inline strings
        IEnumerable<WorksheetPart> worksheetParts = workbook.GetPartsOfType<WorksheetPart>();

        foreach (var worksheet in worksheetParts)
        {
            DoReplace(worksheet.Worksheet.Descendants<Text>());
        }

        int z = 40;
        foreach (System.Data.DataRow row in ExcelWorkXLSX.ToOut.Rows)
        {
            for (int i = 0; i < row.ItemArray.Count(); i++)
            { 
                ExcelWorkXLSX.InsertText(workbook, row.ItemArray.ElementAt(i).ToString(), getColumnName(i), Convert.ToUInt32(z)); }
                z++;
            }
        } 

    }
}

Ale ten fragment wypisze DataTable slooooooooooooooooooooooowwwwwww ...

Jak szybko i prawdziwie eksportować tabelę danych do programu Excel?

questionAnswers(7)

yourAnswerToTheQuestion