下载Excel文件

5

我之前问过这个问题,但在启动文件下载方面仍然有困难。

var fileName = "ExcelData.xlsx";
var file = new FileInfo(fileName);
using (var package = new OfficeOpenXml.ExcelPackage(file))
{
   var worksheet = package.Workbook.Worksheets.FirstOrDefault(x => x.Name == "Employee Data");
   if (package.Workbook.Worksheets.FirstOrDefault(x => x.Name == "Employee Data") == null)
   {
       worksheet = package.Workbook.Worksheets.Add("Employee Data");
   }
   else
   {
       package.Workbook.Worksheets.Delete(1);
       worksheet = package.Workbook.Worksheets.Add("Employee Data");
    }
     worksheet.Cells[1, 1].Value = "Date start";
     worksheet.Cells[1, 2].Value = "Name";

     var rowCounter = 2;
      foreach (var v in users)
      {
         string dt = v.DateAdded.ToString();
         worksheet.Cells[rowCounter, 1].Value = dt;
         worksheet.Cells[rowCounter, 2].Value = v.Name;
         rowCounter++;
      }
      package.Workbook.Properties.Title = "Employee Data";

      System.Web.HttpResponse response = System.Web.HttpContext.Current.Response;
      response.Clear();
      response.Buffer = true;
      response.Charset = "";
      response.ContentType = "application/vnd.openxmlformats-     officedocument.spreadsheetml.sheet";
      response.AddHeader("content-disposition", "attachment;filename=ExcelData.xlsx");
      response.BinaryWrite(package.GetAsByteArray());
}

目前代码没有报错,但下载也没有被触发。如何触发下载,使生成的文件被保存到默认下载文件夹中。


尝试将 response.Clear(); 这行注释掉。 - Pankaj Kapare
2个回答

6

为什么不返回 FileContentResult

因为你正在使用的 Excel 库可以将工作表作为字节数组返回,所以这可能适用于你。

在你的控制器中,你只需像这样返回 FileContentResult

return File(package.GetAsByteArray(), "application/xlsx", "YourReportName.xlsx");

所以您可以从您的代码中移除这个块:

System.Web.HttpResponse response = System.Web.HttpContext.Current.Response;
  response.Clear();
  response.Buffer = true;
  response.Charset = "";
  response.ContentType = "application/vnd.openxmlformats-     officedocument.spreadsheetml.sheet";
  response.AddHeader("content-disposition", "attachment;filename=ExcelData.xlsx");
  response.BinaryWrite(package.GetAsByteArray());

只需按上述示例返回文件即可。

请注意,您需要在控制器中添加一个System.Web.Mvc的using语句。


2

在你的代码后尝试:

Response.Flush();
Response.Close();
Response.End();

它会立即输出结果。


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接