Как добавить новую строку и столбцы с 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> @order.Id</td>
<td colspan="6"><b>Buy date:</b> @order.CreatedDate</td>
</tr>
foreach (var osku in order.OrderSKUViewModels)
{
<tr>
<td colspan="3"><b>Product name:</b> @osku.SKUName</td>
<td colspan="5"><b>Quantity:</b> @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>