c# - C# OpenXML 使 Excel 文件可下载
问题描述
[EnableCors(origins: "*", headers: "*", methods: "*")]
public class ExcelReportsController : Controller
{
private ExcelContext db = new ExcelContext();
[Route("/ExportToExcel")]
[HttpGet]
public void ExportPersonsToExcel()
{
var sqlParameters = new List<SqlParameter>();
sqlParameters.Add(new SqlParameter("@id", "1"));
var persons = db.Database.SqlQuery<TestExcel>("SELECT * FROM persons(@id)", sqlParameters.ToArray()).ToArray();
DataTable table = (DataTable)JsonConvert.DeserializeObject(JsonConvert.SerializeObject(persons), (typeof(DataTable)));
using (SpreadsheetDocument document = SpreadsheetDocument.Create("TestNewData.xlsx", SpreadsheetDocumentType.Workbook))
{
WorkbookPart workbookPart = document.AddWorkbookPart();
workbookPart.Workbook = new Workbook();
WorksheetPart worksheetPart = workbookPart.AddNewPart<WorksheetPart>();
var sheetData = new SheetData();
worksheetPart.Worksheet = new Worksheet(sheetData);
Sheets sheets = workbookPart.Workbook.AppendChild(new Sheets());
Sheet sheet = new Sheet() { Id = workbookPart.GetIdOfPart(worksheetPart), SheetId = 1, Name = "Sheet1" };
sheets.Append(sheet);
Row headerRow = new Row();
List<String> columns = new List<string>();
foreach (DataColumn column in table.Columns)
{
columns.Add(column.ColumnName);
Cell cell = new Cell();
cell.DataType = CellValues.String;
cell.CellValue = new CellValue(column.ColumnName);
headerRow.AppendChild(cell);
}
sheetData.AppendChild(headerRow);
foreach (DataRow dsrow in table.Rows)
{
Row newRow = new Row();
foreach (String col in columns)
{
Cell cell = new Cell();
cell.DataType = CellValues.String;
cell.CellValue = new CellValue(dsrow[col].ToString());
newRow.AppendChild(cell);
}
sheetData.AppendChild(newRow);
}
workbookPart.Workbook.Save();
}
}
}
}
我有以下代码,但是当我要求提供 excel 文件时,没有任何反应。我希望它在我输入该 URL 时自动下载。有什么解决办法吗?
也许是流?但是我将如何实现呢?我是使用这个库的新手——所以请耐心等待。
解决方案
首先,将方法的返回类型更改为IActionResult
然后,在using
块之后,添加以下内容:
var stream = System.IO.File.Open("TestNewData.xlsx", FileMode.Open);
return File(stream, "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet");
它从您的文件创建一个FileStream
,然后返回一个FileStreamResult
. 长字符串是Microsoft Excel (OpenXML) 的 MIME 类型。注意,FileStreamResult
应该自动处理流。
如果您希望为下载的文件提供名称,可以使用 的重载版本File
,因此只需传递第三个参数(字符串类型),如下所示:
return File(stream, "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet", "CustomName.xlsx");
推荐阅读
- ruby-on-rails - 作为守护进程启动时无法重新启动生产 Rails 服务器
- r - Flexdashboard 中循环内的 GGPlot
- php - 如何从 laravel 的存储中删除图像?
- html - 我的角度控制器不向 c# 控制器发送数据
- html - 网站图标未显示在登台服务器上
- python - 根据列中找到的阈值向上移动 DataFrame 列
- jenkins - 如果作业通过,则使 Jenkins 节点脱机
- c++ - 模板代码的行为与对应部分不同
- angular - 剑道滚动视图(角度)下一个/上一个方法使用
- angular - 无法在“Day View Scheduler”角度日历中刷新日历