无法在C#中使用epplus从dataTable导出excel文件

时间:2016-08-08 04:29:23

标签: c# excel

我已经找到了很多关于如何使用epplus将DataTable导出为Excel的示例和教程,但是找不到直接的方法。因此我尝试了以下代码..

我的dataTable:

===============================
d1    | d2    |  d3
===============================
aa1   | bb1   | cc1
aa2   | bb2   | cc2
aa3   | bb3   | cc3
aa4   | bb4   | cc4

脚本:

using OfficeOpenXml;
using OfficeOpenXml.Drawing;

//........
    protected viod exportToExcel (dataTable dt)
    {
        try
        {

            Response.Clear();
            Response.ContentType = "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet";
            Response.AddHeader("content-disposition", "attachment;filename=" + HttpUtility.UrlEncode("Logs.xlsx", System.Text.Encoding.UTF8));

            using (ExcelPackage pck = new ExcelPackage())
            {
               ExcelWorksheet ws = pck.Workbook.Worksheets.Add("Logs");
                ws.Cells["A1"].LoadFromDataTable(dt, true);                 
                var ms = new System.IO.MemoryStream();
                pck.SaveAs(ms);
                ms.WriteTo(Response.OutputStream);                          
            }

        }
        catch (Exception ex)
        {
            Debug("error: " + ex.Message);//catch nothing
        }

    }

它返回服务器错误,没有捕获任何异常,所以我不知道发生了什么错误..

但是,删除

时不会发生错误
using (ExcelPackage pck = new ExcelPackage())
上面代码中的

部分。

有什么想法吗?

1 个答案:

答案 0 :(得分:0)

从服务器导出到Excel的最佳方法,将数据表转换为HtmlTextWriter。 在里面 Response.AddHeader("内容处置""附件;文件名= file.xls&#34);

Response.ContentType ="应用程序/ vnd.ms-的excel&#34 ;; 最后

Response.Output.Write(htmltexwriter)