首頁 >後端開發 >C++ >如何在 C# 中有效率地將 DataTable 轉換為 CSV 檔案?

如何在 C# 中有效率地將 DataTable 轉換為 CSV 檔案?

Patricia Arquette
Patricia Arquette原創
2025-01-15 15:31:42918瀏覽

How to Efficiently Convert a DataTable to a CSV File in C#?

C#中DataTable到CSV的轉換

將DataTable資料儲存到CSV檔案時,可能會遇到資料分隔不正確的問題。以下提供解決方案:

考慮以下程式碼:

<code class="language-csharp">StringBuilder sb = new StringBuilder();
foreach (DataColumn col in dt.Columns)
{
    sb.Append(col.ColumnName + ',');
}
sb.Remove(sb.Length - 1, 1);
sb.Append(Environment.NewLine);

foreach (DataRow row in dt.Rows)
{
    // ... (此处代码仅写入每一行的第一个单元格数据) ...
}

File.WriteAllText("test.csv", sb.ToString());</code>

上述程式碼所建立的CSV檔案僅包含每行第一個儲存格的資料。為了解決這個問題,可以使用更健壯的方法:

.NET 3.5以上版本

<code class="language-csharp">StringBuilder sb = new StringBuilder();
string[] columnNames = dt.Columns.Cast<DataColumn>().Select(column => column.ColumnName).ToArray();
sb.AppendLine(string.Join(",", columnNames));

foreach (DataRow row in dt.Rows)
{
    string[] fields = row.ItemArray.Select(field => field.ToString()).ToArray();
    sb.AppendLine(string.Join(",", fields));
}

File.WriteAllText("test.csv", sb.ToString());</code>

.NET 4.0以上版本

對於.NET 4.0以上版本,程式碼可以再簡化:

<code class="language-csharp">StringBuilder sb = new StringBuilder();
IEnumerable<string> columnNames = dt.Columns.Cast<DataColumn>().Select(column => column.ColumnName);
sb.AppendLine(string.Join(",", columnNames));

foreach (DataRow row in dt.Rows)
{
    IEnumerable<string> fields = row.ItemArray.Select(field => field.ToString());
    sb.AppendLine(string.Join(",", fields));
}

File.WriteAllText("test.csv", sb.ToString());</code>

處理特殊字元

如果需要處理資料欄位中的特殊字元(例如雙引號),可以修改程式碼中的循環區塊:

<code class="language-csharp">foreach (DataRow row in dt.Rows)
{
    IEnumerable<string> fields = row.ItemArray.Select(field =>
        string.Concat("\"", field.ToString().Replace("\"", "\"\""), "\""));
    sb.AppendLine(string.Join(",", fields));
}</code>

此外,為了避免記憶體中出現大型文檔,可以逐行寫入CSV內容,而不是一次寫入整個文檔。

以上是如何在 C# 中有效率地將 DataTable 轉換為 CSV 檔案?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn