C# 将DataTable数据导出到CSV文件

代码:

  public static void ImportToCSV(DataTable dt, string fileName)
        {
            FileStream fs = null;
            StreamWriter sw = null;
            try
            {
                fs = new FileStream(fileName, FileMode.Create, FileAccess.Write);
                sw = new StreamWriter(fs, Encoding.Default);
                string head = "";
                //拼接列头
                for (int cNum = 0; cNum < dt.Columns.Count; cNum++)
                {
                    head += dt.Columns[cNum].ColumnName + ",";
                }
                //csv文件写入列头
                sw.WriteLine(head);
                string data = "";
               //csv写入数据
                for (int i = 0; i < dt.Rows.Count; i++)
                {
                    string data2 = string.Empty;
                    //拼接行数据
                    for (int cNum1 = 0; cNum1 < dt.Columns.Count; cNum1++)
                    {
                        data2 = data2 + "\"" + dt.Rows[i][dt.Columns[cNum1].ColumnName].ToString() + "\",";
                    }
                    bool flag = data != data2;
                    if (flag)
                    {
                        sw.WriteLine(data2);
                    }
                    data = data2;
                    
                }
            }
            catch (Exception ex)
            {
                logger.Error("导出csv失败!" + ex.Message);
                return;
            }
            finally
            {
                if (sw != null)
                {
                    sw.Close();
                }
                if (fs != null)
                {
                    fs.Close();
                }
                sw = null;
                fs = null;
            }
        }

 

下面是 C# 中读写 CSV 文件并使用 `DataTable` 相互转换的示例代码: ```csharp using System; using System.Data; using System.IO; class Program { static void Main(string[] args) { // 读取 CSV 文件DataTable DataTable dataTable = new DataTable(); using (var reader = new StreamReader(@"C:\data.csv")) { while (!reader.EndOfStream) { var line = reader.ReadLine(); var values = line.Split(','); // 第一行数据作为列名 if (dataTable.Columns.Count == 0) { foreach (var value in values) { dataTable.Columns.Add(value.Trim()); } } else { // 处理每行数据 DataRow row = dataTable.NewRow(); for (int i = 0; i < values.Length; i++) { row[i] = values[i].Trim(); } dataTable.Rows.Add(row); } } } // 将 DataTable 写入 CSV 文件 using (var writer = new StreamWriter(@"C:\output.csv")) { // 写入列名 for (int i = 0; i < dataTable.Columns.Count; i++) { writer.Write(dataTable.Columns[i]); if (i < dataTable.Columns.Count - 1) { writer.Write(","); } } writer.WriteLine(); // 写入数据 foreach (DataRow row in dataTable.Rows) { for (int i = 0; i < dataTable.Columns.Count; i++) { writer.Write(row[i].ToString()); if (i < dataTable.Columns.Count - 1) { writer.Write(","); } } writer.WriteLine(); } } Console.WriteLine("CSV 文件读取和写入完成!"); } } ``` 在这个示例代码中,我们使用 `StreamReader` 类来读取指定路径下的 CSV 文件,使用 `DataTable` 类来保存读取到的数据,同时将其转换为 `DataTable` 对象。我们遍历读取到的每行数据,并将第一行数据作为列名,将每行数据添加到 `DataTable` 中。接着我们使用 `StreamWriter` 类来创建一个新的 CSV 文件,并将 `DataTable` 对象中的数据写入文件中。最后,程序输出一条消息表示 CSV 文件操作完成。 如果需要在程序中使用 `DataTable` 对象进行数据处理,可以使用以下代码将 `DataTable` 转换为 CSV 文件: ```csharp // 将 DataTable 写入 CSV 文件 using (var writer = new StreamWriter(@"C:\output.csv")) { // 写入列名 for (int i = 0; i < dataTable.Columns.Count; i++) { writer.Write(dataTable.Columns[i]); if (i < dataTable.Columns.Count - 1) { writer.Write(","); } } writer.WriteLine(); // 写入数据 foreach (DataRow row in dataTable.Rows) { for (int i = 0; i < dataTable.Columns.Count; i++) { writer.Write(row[i].ToString()); if (i < dataTable.Columns.Count - 1) { writer.Write(","); } } writer.WriteLine(); } } ``` 这段代码将 `DataTable` 的列名和每行数据写入CSV 文件中。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

tiegenZ

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

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

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

打赏作者

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

抵扣说明:

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

余额充值