在C#中,使用DataTable
進行數據的導入和導出可以通過多種方式實現。以下是一個基本的方案,包括如何創建DataTable
,如何將其導出為CSV文件以及如何從CSV文件導入數據到DataTable
。
首先,你需要創建一個DataTable
對象并定義其列。
DataTable dt = new DataTable();
dt.Columns.Add("ID", typeof(int));
dt.Columns.Add("Name", typeof(string));
dt.Columns.Add("Age", typeof(int));
要將DataTable
導出為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));
// 寫入數據行
foreach (DataRow row in dt.Rows)
{
string[] values = row.ItemArray.Select(v => v?.ToString()).ToArray();
sw.WriteLine(string.Join(",", values));
}
}
從CSV文件導入數據到DataTable
稍微復雜一些,因為你需要處理可能的錯誤和分隔符問題。以下是一個簡單的示例:
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);
// 讀取數據行
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);
}
}
注意:這個示例假設CSV文件的每一行都有相同數量的列,并且列名在第一行。在實際應用中,你可能需要添加一些錯誤處理和驗證邏輯。
以上方案提供了一個基本的框架,用于在C#中使用DataTable
進行數據的導入和導出。根據你的具體需求,你可能需要對這個方案進行調整和擴展。例如,你可能需要處理不同的分隔符、引用逗號、換行符等問題,或者添加更多的錯誤處理和驗證邏輯。