问题描述
我正在使用 blazor 和 .net 5。我正在尝试使用 ClosedXML 进行 excel 导出。这是我写的简单方法:
public IActionResult CreateExcelSheet()
{
using (var wbook = new XLWorkbook())
{
var ws = wbook.Worksheets.Add("Sheet1");
ws.Cell("A1").Value = "1";
using (var stream = new MemoryStream())
{
wbook.SaveAs(stream);
var content = stream.ToArray();
return File(content,"application/vnd.openxmlformats-officedocument.spreadsheetml.sheet","Opportunities.xlsx");
}
}
}
返回文件有一个红色下划线,表示不可调用成员“文件”不能像方法一样使用。 我不太确定如何纠正这个问题......我也不确定我是否在使用 blazor 和 .net 5 时做对了。非常感谢任何帮助!
解决方法
我试过了,它对我有用。 您的 URI 是 GET https:/api/sample/excel。
示例:https://localhost:44370/api/Sample/excel
using System;
using Microsoft.AspNetCore.Authorization;
using Microsoft.AspNetCore.Mvc;
using Microsoft.AspNetCore.Http;
using ClosedXML.Excel;
namespace YourProject.API.Controllers
{
[Route("api/[controller]")]
[ApiController]
public class SampleController : ControllerBase
{
[HttpGet("excel")]
[AllowAnonymous]
public IActionResult CreateExcelSheet()
{
try
{
using (var wbook = new XLWorkbook())
{
var ws = wbook.Worksheets.Add("Sheet1");
ws.Cell("A1").Value = "1";
using (var stream = new System.IO.MemoryStream())
{
wbook.SaveAs(stream);
var content = stream.ToArray();
return File(content,"application/vnd.openxmlformats-officedocument.spreadsheetml.sheet","Opportunities.xlsx");
}
}
}
catch (Exception ex)
{
return StatusCode(StatusCodes.Status500InternalServerError);
}
}
}
}