微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

ClosedXML 返回文件

如何解决ClosedXML 返回文件

我正在使用 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);
            }
        }
    }
}

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。