C#操作写入Csv文件简单易用

首先添加引用: Nuget包里搜索CsvHelper,作者是Josh Close ,下载量蛮高的有111M

创建一个测试类

public class Ad
        {
            public string Name { get; set; }
            public string Description { get; set; }
                
        }
        //赋值
       Ad a = new Ad();
            a.Name = "CSDN";
            a.Description = "我爱你"; 
            //调用并写入csv
             List<Ad> records = new List<Ad>();
             records.Add(a);
             //写CSV文件
             using (var writer = new StreamWriter("D:\\1.csv",false,Encoding.UTF8) )
             using (var csv = new CsvWriter(writer, CultureInfo.InvariantCulture))
             {
                 csv.WriteRecords(records);
             } 
            

分享一个自己写的方法

 public class CsvExportHelper
    {
        public static bool CreateAdvExcel<T>(IList<T> lt, string path)
        {
            try
            {
                StringBuilder builder = new StringBuilder();
                System.Reflection.PropertyInfo[] myPropertyInfo = lt.First().GetType().GetProperties(System.Reflection.BindingFlags.Public | System.Reflection.BindingFlags.Instance);
                int i = 0, j;
                for (i = 0, j = myPropertyInfo.Length; i < j; i++)
                {
                    System.Reflection.PropertyInfo pi = myPropertyInfo[i];
                    string headname = pi.Name;//单元格头部
                    var attrs = pi.GetCustomAttributes(typeof(DisplayNameAttribute), true);
                    if (attrs != null && attrs.Count() > 0)
                    {
                        headname = ((DisplayNameAttribute)attrs[0]).DisplayName;
                    }
                    builder.Append(headname);
                    builder.Append("\t");
                }
                builder.Append("\n");
                foreach (var t in lt)
                {
                    if (lt == null)
                    {
                        continue;
                    }
                    for (i = 0, j = myPropertyInfo.Length; i < j; i++)
                    {
                        System.Reflection.PropertyInfo pi = myPropertyInfo[i];
                        string str = string.Format("{0}", pi.GetValue(t, null)).Replace("\n", "");
                        if (str == "")
                        {
                            builder.Append("\t");
                        }
                        else
                        {
                            builder.Append(str + "\t");//横向跳到另一个单元格
                        }
                    }
                    builder.Append("\n");//换行
                }
                using (StreamWriter sw = new StreamWriter(path, false, System.Text.Encoding.GetEncoding("GB2312")))
                {
                    sw.Write(builder.ToString());//输出
                    sw.Flush();
                    sw.Close();
                }
                return true;
            }
            catch (Exception ex)
            {
                Console.WriteLine(ex.Message);
                return false;
            }

        }
    }
以下是一个简单的示例,演示如何在 C# 中使用线程写入 CSV 格式文件: ```csharp using System; using System.IO; using System.Threading; namespace CSVWriterExample { class Program { static void Main(string[] args) { // 创建线程 Thread thread = new Thread(new ThreadStart(WriteToCSV)); // 启动线程 thread.Start(); Console.WriteLine("Press any key to exit."); Console.ReadKey(); } static void WriteToCSV() { // 创建一个 CSV 文件写入标题行 string filePath = "data.csv"; using (StreamWriter writer = new StreamWriter(filePath)) { writer.WriteLine("Name, Age, Gender"); // 模拟写入数据 for (int i = 0; i < 10; i++) { string name = "Person " + i; int age = i + 20; string gender = i % 2 == 0 ? "Male" : "Female"; // 写入数据行 writer.WriteLine("{0}, {1}, {2}", name, age, gender); } } Console.WriteLine("Data written to CSV file."); } } } ``` 在上面的示例中,我们创建了一个名为 `WriteToCSV` 的方法,该方法模拟写入一些数据到 CSV 文件。我们使用 `StreamWriter` 类来写入文件并使用 `Thread` 类创建一个新线程来执行 `WriteToCSV` 方法。 请注意,我们在主线程中启动了新线程,并等待用户按下任意键后退出程序。这是因为我们希望新线程能够有足够的时间来完成写入操作。如果我们不等待新线程完成写入操作,那么程序可能会在写入操作完成之前退出,从而导致数据丢失。 在实际使用中,请根据您的需求修改代码,确保代码能够正确地写入 CSV 文件并处理任何可能出现的异常。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

no longer

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值