Как создать файл Excel с несколькими листами из DataSet, используя C # - PullRequest
9 голосов
/ 16 ноября 2011

Как создать файл Excel с несколькими листами из DataSet, используя C #.Я успешно создал файл Excel с одним листом.Но я не могу сделать это для нескольких листов.

С уважением Суровый

Ответы [ 2 ]

16 голосов
/ 30 декабря 2011

Вот простой класс C #, который программно создает рабочую книгу Excel и добавляет к ней два листа, а затем заполняет оба листа.Наконец, он сохраняет рабочую книгу в файл в корневом каталоге приложения, чтобы вы могли проверить результаты ...

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 к вашему проекту (вы, возможно, сделали это уже, так как вы создаете один лист).

Оператор, который добавляет второй лист: ...

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

аргумент '1' указывает один лист, и может быть больше, если вы хотите добавить несколько листов одновременно.

Конечное примечание: утверждение oXL.Visible = false;говорит Excel запустить в автоматическом режиме.

0 голосов
/ 21 июня 2019
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);
    }
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...