Запись файла Excel в EPPlus
Я застрял на этом в течение нескольких дней, и, несмотря на всю помощь, ни одно из этих решений не помогло мне. Я хочу создать файл Excel с использованием библиотеки EPPlus, содержащей некоторые базовые данные, которые я извлекаю из хранимой процедуры. Это код, который я имею в моем файле ExportDocument.cs:
public static ExcelPackage CreateExcelDocument(int [] arr)
{
String path = @"D:\temp\testsheet3.xlsx";
//FileInfo newFile = null;
/*if (!File.Exists(path + "\\testsheet2.xlsx"))
newFile = new FileInfo(path + "\\testsheet2.xlsx");
else
return newFile;*/
using (ExcelPackage package = new ExcelPackage())
{
ExcelWorksheet ws = package.Workbook.Worksheets.Add("testsheet");
ws.Cells["B1"].Value = "Number of Used Agencies";
ws.Cells["C1"].Value = "Active Agencies";
ws.Cells["D1"].Value = "Inactive Agencies";
ws.Cells["E1"].Value = "Total Hours Volunteered";
ws.Cells["B1:E1"].Style.Font.Bold = true;
int x = 2;
char pos = 'B';
foreach (object o in arr)
{
String str = pos + x.ToString();
ws.Cells[str].Value = o.ToString();
if (pos > 'E')
{
pos = 'B';
x++;
}
pos++;
}
package.Save();
return package;
}
}
Весь закомментированный код - это разные вещи, которые я нашел в интернете, чтобы попробовать. Обратите внимание, что это школьная организация, и мы не используем MVC. Затем я использую код позади файла, чтобы вытащить этот метод следующим образом:
protected void GenerateReport(Object o, EventArgs e)
{
Session["reportSession"] = ddReport.SelectedItem.Value.ToString();
int [] arr = new int [ReportRepository.GetAgencyCounts().Count];
ReportRepository.GetAgencyCounts().CopyTo(arr, 0);
ExcelPackage pck = ExportDocument.CreateExcelDocument(arr);
/*try
{
byte [] data = ExportDocument.CreateExcelDocument(arr).GetAsByteArray();
Response.Clear();
Response.Buffer = true;
Response.BinaryWrite(data);
Response.AddHeader("content-length", data.Length.ToString());
Response.ContentType = "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet";
Response.Flush();
Response.Close();
Response.End();
}
catch (Exception ex) { }*/
/*var stream = new MemoryStream();
pck.SaveAs(stream);
String filename = "myfile.xlsx";
String contentType = "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet";
var cd = new System.Net.Mime.ContentDisposition
{
Inline = false,
FileName = filename
};
Response.AppendHeader("Content-Disposition", cd.ToString());
stream.Position = 0;
return File(stream, contentType, filename);*/
/*Response.ContentType = "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet";
Response.AppendHeader("Content-Disposition", "attachment; filename=" + file.Name);
Response.TransmitFile(Path.GetFullPath(file.Name));
Response.Flush();
Response.Close();*/
/*Response.ClearHeaders();
Response.BinaryWrite(pck.GetAsByteArray());
Response.ContentType = "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet";
Response.AddHeader("content-disposition", "attachment; filename=Sample2.xlsx");
Response.Flush();
Response.Close();*/
}
Еще раз обратите внимание, что весь закомментированный код - это то, что я нашел из разных источников, которые не работали.
Так что я не получаю никаких ошибок, но когда я нажимаю кнопку в моем приложении, чтобы выполнить метод кода, ничего не происходит. Он загружается и запускается, но файлы не создаются, ничего не открывается. Это первый раз, когда я использую EPPlus, и я не совсем знаком с экспортом вещей, чтобы преуспеть программно, поэтому я чувствую себя потерянным здесь.
Есть какие-нибудь предложения, которые у вас есть, ребята? Я был бы рад уточнить любые моменты, которые я также не затронул полностью.
Ответы
Ответ 1
Посмотрели ли вы образцы, предоставленные с помощью EPPlus?
Это показывает, как создать файл
http://epplus.codeplex.com/wikipage?title=ContentSheetExample
Это показывает, как использовать его для потоковой передачи файла
http://epplus.codeplex.com/wikipage?title=WebapplicationExample
Вот как мы используем пакет для создания файла.
var newFile = new FileInfo(ExportFileName);
using (ExcelPackage xlPackage = new ExcelPackage(newFile))
{
// do work here
xlPackage.Save();
}
Ответ 2
Лучше всего, если вы работали с DataSet
и/или DataTable
s. Если у вас есть это, в идеале прямо из вашей хранимой процедуры с соответствующими именами столбцов для заголовков, вы можете использовать следующий метод:
ws.Cells.LoadFromDataTable(<DATATABLE HERE>, true, OfficeOpenXml.Table.TableStyles.Light8);
.., который создаст красивую таблицу с красивым столом!
Теперь, чтобы обслуживать ваш файл, предположим, что у вас есть объект ExcelPackage
, как в вашем коде выше, называемом pck
..
Response.Clear();
Response.ContentType = "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet";
Response.AddHeader("Content-Disposition", "attachment;filename=" + sFilename);
Response.BinaryWrite(pck.GetAsByteArray());
Response.End();
Ответ 3
Если у вас есть коллекция объектов, которые вы загружаете с помощью хранимой процедуры, вы также можете использовать LoadFromCollection
.
using (ExcelPackage package = new ExcelPackage(file))
{
ExcelWorksheet worksheet = package.Workbook.Worksheets.Add("test");
worksheet.Cells["A1"].LoadFromCollection(myColl, true, OfficeOpenXml.Table.TableStyles.Medium1);
package.Save();
}