C#——DataTable数据写入.csv文件中

/***********************
Author: Tst
CSDN blog: Ricardo.M.Tan
************************/

using System;
using System.Collections.Generic;
using System.Data;
using System.IO;
using System.Linq;
using System.Text;

namespace Chn.gzGISer.Utility
{
    /// <summary>
    /// CSV文件读写扩展方法
    /// </summary>
    public class CSVExten
    {
        /// <summary>
        /// 将内存中的数据表写入.csv文件中
        /// </summary>
        /// <param name="table">DataTable表</param>
        /// <param name="path">路径</param>
        /// <param name="writeSize">一次读写的最大长度</param>
        /// <returns>返回bool值,true 成功, false 失败</returns>
        public static bool DataTableWriteToCsvFile(DataTable table, string path, int writeSize)
        {
            //以半角逗号(即,)作分隔符,列为空也要表达其存在。
            //列内容如存在半角逗号(即,)则用半角引号(即"")将该字段值包含起来。
            //列内容如存在半角引号(即")则应替换成半角双引号("")转义,并用半角引号(即"")将该字段值包含起来。
            StringBuilder sb = new StringBuilder();
            try
            {
                int rowCount = table.Rows.Count;
                if (rowCount > writeSize)
                {
                    int count = 0;
                    foreach (DataRow row in table.Rows)
                    {
                        for (int i = 0; i < table.Columns.Count; i++)
                        {
                            if (i != 0)
                            {
                                sb.Append(",");
                            }
                            DataRowToDataString(row, table.Columns[i], ref sb);
                        }
                        sb.AppendLine();
                        count++;
                        if (count == writeSize)
                        {
                            File.AppendAllText(path, sb.ToString());
                            sb.Clear();
                            count = 0;
                        }
                    }
                    if (count > 0)
                    {
                        File.AppendAllText(path, sb.ToString());
                    }
                    sb.Clear();
                    sb = null;
                    return true;
                }
                else
                {
                    foreach (DataRow row in table.Rows)
                    {
                        for (int i = 0; i < table.Columns.Count; i++)
                        {
                            if (i != 0) sb.Append(",");
                            DataRowToDataString(row, table.Columns[i], ref sb);
                        }
                        sb.AppendLine();
                    }
                    File.WriteAllText(path, sb.ToString());
                    sb.Clear();
                    sb = null;
                    return true;
                }
            }
            catch (Exception)
            {

                throw;
            }
            finally
            {
                sb.Clear();
                sb = null;
            }
        }

        private static void DataRowToDataString(DataRow row, DataColumn column, ref StringBuilder sb)
        {
            if (column.DataType == typeof(string) && row[column].ToString().Contains(","))
            {
                sb.Append("\"" + row[column].ToString().Replace("\"", "\"\"") + "\"");
            }
            else
            {
                sb.Append(row[column].ToString());
            }
        }
    }
}

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,这是一个关于C#文件操作的问题,我会尽力回答。 首先,您需要使用System.IO命名空间的类来进行文件操作。您可以使用File类来创建、打开、读取和写入文件,使用Directory类来创建文件夹。然后,您可以使用System.Data命名空间的类来创建和操作DataTable。 以下是一个简单的代码示例,用于点击历史记录时判断是否需要创建文件夹并将DataTable数据写入CSV文件: ```csharp using System; using System.IO; using System.Data; using System.Text; // 根据需要修改命名空间 class Program { static void Main() { // 假设您已经获取了需要写入CSV文件数据,存储在一个名为"dataTable"的DataTable // 指定CSV文件名和路径 string csvFilePath = @"C:\Users\YourUsername\Documents\example.csv"; // 判断文件夹是否存在,不存在则创建 string directoryPath = Path.GetDirectoryName(csvFilePath); if (!Directory.Exists(directoryPath)) { Directory.CreateDirectory(directoryPath); } // 将DataTable数据写入CSV文件 StringBuilder sb = new StringBuilder(); // 添加表头 foreach (DataColumn column in dataTable.Columns) { sb.Append(column.ColumnName).Append(","); } sb.AppendLine(); // 添加数据 foreach (DataRow row in dataTable.Rows) { for (int i = 0; i < dataTable.Columns.Count; i++) { sb.Append(row[i].ToString()).Append(","); } sb.AppendLine(); } // 将StringBuilder的内容写入文件 File.WriteAllText(csvFilePath, sb.ToString()); // 完成,CSV文件已经被写入 } } ``` 请注意,此示例仅用于演示目的,实际应用可能需要进行更多的错误处理和异常处理。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值