C# DataTable數(shù)據(jù)導(dǎo)入導(dǎo)出方案

c#
小樊
81
2024-10-12 19:07:21

在C#中,使用DataTable進(jìn)行數(shù)據(jù)的導(dǎo)入和導(dǎo)出可以通過(guò)多種方式實(shí)現(xiàn)。以下是一個(gè)基本的方案,包括如何創(chuàng)建DataTable,如何將其導(dǎo)出為CSV文件以及如何從CSV文件導(dǎo)入數(shù)據(jù)到DataTable。

1. 創(chuàng)建DataTable

首先,你需要?jiǎng)?chuàng)建一個(gè)DataTable對(duì)象并定義其列。

DataTable dt = new DataTable();
dt.Columns.Add("ID", typeof(int));
dt.Columns.Add("Name", typeof(string));
dt.Columns.Add("Age", typeof(int));

2. 導(dǎo)出DataTable為CSV文件

要將DataTable導(dǎo)出為CSV文件,你可以使用StreamWriter。

string filePath = "data.csv";
using (StreamWriter sw = new StreamWriter(filePath))
{
    // 寫入列名
    string[] columns = dt.Columns.Select(c => c.ColumnName).ToArray();
    sw.WriteLine(string.Join(",", columns));

    // 寫入數(shù)據(jù)行
    foreach (DataRow row in dt.Rows)
    {
        string[] values = row.ItemArray.Select(v => v?.ToString()).ToArray();
        sw.WriteLine(string.Join(",", values));
    }
}

3. 從CSV文件導(dǎo)入數(shù)據(jù)到DataTable

從CSV文件導(dǎo)入數(shù)據(jù)到DataTable稍微復(fù)雜一些,因?yàn)槟阈枰幚砜赡艿腻e(cuò)誤和分隔符問(wèn)題。以下是一個(gè)簡(jiǎn)單的示例:

string filePath = "data.csv";
DataTable dt = new DataTable();

using (StreamReader sr = new StreamReader(filePath))
{
    // 讀取列名
    string[] columns = sr.ReadLine().Split(',').Select(s => s.Trim()).ToArray();
    dt.Columns.AddRange(columns);

    // 讀取數(shù)據(jù)行
    while (!sr.EndOfStream)
    {
        string[] values = sr.ReadLine().Split(',').Select(s => s.Trim()).ToArray();
        DataRow row = dt.NewRow();
        for (int i = 0; i < values.Length; i++)
        {
            row[i] = Convert.ChangeType(values[i], dt.Columns[i].DataType);
        }
        dt.Rows.Add(row);
    }
}

注意:這個(gè)示例假設(shè)CSV文件的每一行都有相同數(shù)量的列,并且列名在第一行。在實(shí)際應(yīng)用中,你可能需要添加一些錯(cuò)誤處理和驗(yàn)證邏輯。

總結(jié)

以上方案提供了一個(gè)基本的框架,用于在C#中使用DataTable進(jìn)行數(shù)據(jù)的導(dǎo)入和導(dǎo)出。根據(jù)你的具體需求,你可能需要對(duì)這個(gè)方案進(jìn)行調(diào)整和擴(kuò)展。例如,你可能需要處理不同的分隔符、引用逗號(hào)、換行符等問(wèn)題,或者添加更多的錯(cuò)誤處理和驗(yàn)證邏輯。

0