面向云技术架构 - 痴者工良

  • 首页
  • 工良写的电子书
    • kubernetes 教程
    • 从 C# 入门 Kafka
    • 多线程和异步
    • 动态编程-反射、特性、AOP
    • 表达式树
  • 本站文章导航
  • 隐私政策
愿有人陪你颠沛流离
遇到能让你付出的事物或者人,都是一种运气。
能遇到,就该珍惜。或许你们最终没能在一起,但你会切实地感受到力量。
正因为这样,那段相遇才变得有价值,才没有辜负这世间的每一段相遇。
  1. 首页
  2. .NET
  3. 正文

C# 不依赖框架直接导出为 .CSV

2021年8月23日 1006点热度 0人点赞 0条评论
内容纲要

代码所示,将 Table 导出为 .csv 格式的数据。

        public static async Task SaveCSV(DataTable dt,string[] header, string fileName)
        {
            StringBuilder sb = new StringBuilder();
            sb.Append($"{string.Join(",", header)}\r\n");

            for (int i = 0; i < dt.Rows.Count; i++)
            {
                for (int j = 0; j <= dt.Columns.Count - 1; j++)
                {
                    sb.Append("\"" + dt.Rows[i][j] + "\"" + ",");

                }
                sb.Remove(sb.Length - 1, 1).Append("\r\n"); 
            }
            var bytes = Encoding.UTF8.GetBytes(sb.ToString());
            using FileStream fileStream = new FileStream(fileName, FileMode.CreateNew);
            await fileStream.WriteAsync(bytes);
        }

调用:

                    DataTable dataTable = new DataTable("结果");
                    var header = new List<string>() { "id","name",... };
                    foreach (var item in header)
                    {
                        dataTable.Columns.Add(item,typeof(string));
                    }

                    foreach (var item in exportObj.Values)
                    {
                        DataRow dr = dataTable.NewRow();
                        foreach (var r in item)
                        {
                            dr[r.Key] = r.Value;
                        }
                        dataTable.Rows.Add(dr);
                    }
                    SaveCSV(dataTable, header.ToArray(), filePath).Wait();
本作品采用 知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议 进行许可
标签: c cvs 依赖 导出 框架
最后更新:2021年10月6日

痴者工良

高级程序员劝退师

点赞
< 上一篇
下一篇 >

文章评论

razz evil exclaim smile redface biggrin eek confused idea lol mad twisted rolleyes wink cool arrow neutral cry mrgreen drooling persevering
取消回复

COPYRIGHT © 2022 whuanle.cn. ALL RIGHTS RESERVED.

Theme Kratos Made By Seaton Jiang

粤ICP备18051778号

粤公网安备 44030902003257号