Как добавить новую строку и столбцы с EPPlus C# и MVC?

Я использую EPPlus версии 4.0.4 для создания файла Excel на веб-сайте ASP.net MVC5, и я просто не знаю, как добавить новые строки и столбцы после завершения самой первой строки.

Это сложно объяснить, поэтому давайте я покажу вам свой код. Это достаточно легко понять.

    var products = new DataTable("1km subscriptions");

    // SO HERE THE FIRST COLUMS with ROWS INFORMATION
    products.Columns.Add("", typeof(int));
    products.Columns.Add("Full Name", typeof(string));
    products.Columns.Add("BirthDate", typeof(string));

    int i = 0;
    foreach (var item in GetData())
    {
        // Primary user info
        products.Rows.Add(i, item.FullName, item.BirthDate);
        i++;

        // HERE I HAVE TO GO TO NEXT LIGNE NUMBER AND WRITE TWO COLUMNS AND ROWS INFO
//products.NewRow();
        products.Columns.Add("ORDER #", typeof(int));
        products.Columns.Add("BUY DATE", typeof(string));

        foreach (var order in item.OrderViewModels)
        {
            products.Rows.Add(order.Id, order.CreatedDate);

//products.NewRow();
            // THEN, I HAVE TO DO THE SAME THING. GO TO THE NEXT LIGNE AND ADD TWO OTHERS COLUMNS WITH INFO
            products.Columns.Add("PRODUCT NAME", typeof(string));
            products.Columns.Add("Quantity", typeof(int));
            foreach (var osku in order.OrderSKUViewModels)
            {
                products.Rows.Add(osku.SKUName, osku.Quantity);
            }
        }
    }

    using (ExcelPackage pck = new ExcelPackage())
    {
        ExcelWorksheet ws = pck.Workbook.Worksheets.Add("FIRST TAB NAME");
        ws.Cells["A1"].LoadFromDataTable(products, true)
        // Write it back to the client
        Response.ContentType = "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet";
        Response.AddHeader("content-disposition", "attachment;  filename=ExcelDemo.xlsx");
        Response.BinaryWrite(pck.GetAsByteArray());
        Response.Flush();
        Response.End();
    }

Сначала я думал, что products.NewRow() выполнит эту работу, но это не так. Я не нахожу легким, чтобы мы делали эту легкую операцию. Я бы хотел избежать серьезных изменений в коде для чего-то подобного o_O

Кто-нибудь может помочь?

Дэвид

редактировать

Я не могу добавить изображение, но могу поделиться HTML-кодом, который я использую для отображения данных. Я пытаюсь воспроизвести ту же архитектуру с Excel. Таким образом, мы можем понять, что я думал, что product.NewLine() может произвести вид изменения строки...:

<table class="table table-hover" style="border: 1px solid #ddd;">
            @foreach (var item in Model)
            {
                <tr class="success">
                    <th style="width:122px;">Full Name</th>
                    <th style="width:118px;">BirthDate</th>
                </tr>
                <tr class="active">
                    <td>@item.FullName</td>  
                    <td>@item.BirthDate</td>
                </tr>
                foreach (var order in item.OrderViewModels)
                {
                    <tr>
                        <td><b>Commande:</b></td>
                        <td><b>#</b>&nbsp;@order.Id</td>
                        <td colspan="6"><b>Buy date:</b>&nbsp;@order.CreatedDate</td>
                    </tr>
                        foreach (var osku in order.OrderSKUViewModels)
                        {
                        <tr>
                            <td colspan="3"><b>Product name:</b>&nbsp;@osku.SKUName</td>
                            <td colspan="5"><b>Quantity:</b>&nbsp;@osku.Quantity</td>
                        </tr>
                        }
                    <tr>
                        @if (order.GuestViewModels.Count() != 0)
                        {
                            <th colspan="8" class="success">Guests</th>
                        }
                    </tr>

                    if (order.GuestViewModels.Count() > 0)
                    {
                        <tr class="warning">
                            <th style="width:122px;">FullName</th>
                            <th style="width:118px;">BirthDate</th>
                        </tr>
                    }
                    foreach (var guest in order.GuestViewModels)
                    {
                        <tr style="border-top: 2px double  #0094ff;border-left:2px solid #0094ff;border-right:2px solid #0094ff">
                            <td>@guest.FullName</td>
                            <td>@guest.BirthDate</td>
                        </tr>
                    }
                }
            }
        </table>

0 ответов

Другие вопросы по тегам