ASP.NETCoreCSV文本输出格式化程序使用CsvHelper
创始人
2024-09-17 19:30:34
0
  1. 引入CsvHelper包,并在Startup类中注册服务:
    using CsvHelper.Configuration;
    using Microsoft.AspNetCore.Mvc;
    using Microsoft.Extensions.DependencyInjection;
    using System.Collections.Generic;
    using System.Globalization;
    using System.IO;
    using System.Linq;
    
    public class Startup
    {
        //...
        public void ConfigureServices(IServiceCollection services)
        {
            //...
            services.AddMvc().AddMvcOptions(options =>
            {
                options.OutputFormatters.Add(new CsvOutputFormatter());
            });
        }
        //...
    }
    
  2. 创建一个名为CsvOutputFormatter的类,继承自TextOutputFormatter类,并使用CsvHelper库将对象转换为CSV格式:
    public class CsvOutputFormatter : TextOutputFormatter
    {
        private readonly CsvConfiguration _csvConfiguration;
    
        public CsvOutputFormatter()
        {
            SupportedMediaTypes.Add("text/csv");
            SupportedEncodings.Add(Encoding.UTF8);
            _csvConfiguration = new CsvConfiguration(CultureInfo.InvariantCulture)
            {
                Delimiter = ",",
                HasHeaderRecord = true
            };
        }
    
        protected override bool CanWriteType(Type type)
        {
            if (typeof(IEnumerable).IsAssignableFrom(type) && type != typeof(string))
            {
                return true;
            }
            return base.CanWriteType(type);
        }
    
        public override async Task WriteResponseBodyAsync(OutputFormatterWriteContext context, Encoding selectedEncoding)
        {
            var response = context.HttpContext.Response;
            
            using (var writer = new StreamWriter(response.Body))
            {
                using (var csv = new CsvWriter(writer, _csvConfiguration))
                {
                    var model = context.Object;
                    var modelType = model.GetType();
    
                    if (typeof(IEnumerable).IsAssignableFrom(modelType))
                    {
                        csv.WriteRecords((IEnumerable)model);
                    }
                    else
                    {
                        csv.WriteRecord(model);
                    }
    
                    await writer.FlushAsync();
                }
            }
        }
    }
    
    
    
  3. 最后通过调用相应的控制器操作来调用CsvOutputFormatter并将CSV转换输出到客户端:
    using Microsoft.AspNetCore.Mvc;
    using System.Collections.Generic;
    using System.IO;
    using System.Linq;
    
    public class HomeController : Controller
    {
        //...
        public IActionResult Csv()
        {
    
  4. 相关内容

    热门资讯

    透视新版(wpk俱乐部)德扑人... 1、透视新版(wpk俱乐部)德扑人工智能软件(详细辅助2025版教程)真是真的是有挂;代表性(透视辅...
    德州微扑克辅助!pokerma... 1、德州微扑克辅助!pokermastersteam外挂,(AApOKER)一向真的是有挂(详细透视...
    透视中牌率(wepoke ai... 透视中牌率(wepoke ai辅助)wepoke软件透明挂是真的么(详细辅助教你攻略)确实存在有挂1...
    wpk俱乐部!微扑克怎么加入俱... wpk俱乐部!微扑克怎么加入俱乐部,(aapOker)确实有挂(详细透视解密教程)1、很好的工具软件...
    透视免费(wpk透视辅助)德州... 透视免费(wpk透视辅助)德州wpk辅助真的(详细辅助插件教程)一向是有挂;致您一封信;亲爱wpk透...
    德州之星有外挂!wepower... 德州之星有外挂!wepower系统规律,(AAPOker)往昔有挂(详细辅助AI教程)1、不需要AI...
    透视免费(wepoke真的有挂... 透视免费(wepoke真的有挂)德扑赔率胜率计算(详细辅助可靠教程)一向真的是有挂是一款可以让一直输...
    wepoke辅助德之星!微扑克... 1、wepoke辅助德之星!微扑克发牌算法,(wPk)好像是有挂(详细辅助玩家教你);详细教程。2、...
    wpk发牌逻辑!德州wpk辅助... wpk发牌逻辑!德州wpk辅助,(wpK)从前有挂(详细辅助大神讲解);致您一封信;亲爱wpk发牌逻...
    透视科技(WePoKe透视挂)... 透视科技(WePoKe透视挂)wepoke显示有(详细辅助必胜教程)一直真的是有挂1、在WePoKe...