26

我已经坚持了好几天了,尽管有所有的帮助,但这些解决方案都没有为我工作。我想要做的是使用 EPPlus 库创建一个 excel 文件,其中包含一些我从存储过程中提取的基本数据。这是我的 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,我并不完全熟悉以编程方式将东西导出到 excel,所以我在这里感到迷茫。

你们有什么建议吗?我也很乐意澄清我没有完全理解的任何观点。

4

3 回答 3

36

您看过 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();
}
于 2013-07-03T13:34:09.777 回答
15

最好使用DataSets 和/或DataTables。一旦你有了它,最好是直接从你的存储过程中获得正确的标题列名,你可以使用以下方法:

ws.Cells.LoadFromDataTable(<DATATABLE HERE>, true, OfficeOpenXml.Table.TableStyles.Light8);

.. 这将产生一个漂亮的 excelsheet 和一张漂亮的桌子!

现在为您的文件提供服务,假设您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();
于 2013-07-03T14:13:44.127 回答
10

如果您有一组使用存储过程加载的对象,您也可以使用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();
}
于 2013-12-27T13:52:31.130 回答