Heim > Backend-Entwicklung > C++ > Wie kann ich eine DataTable in C# korrekt in eine CSV-Datei konvertieren?

Wie kann ich eine DataTable in C# korrekt in eine CSV-Datei konvertieren?

DDD
Freigeben: 2025-01-15 15:46:50
Original
462 Leute haben es durchsucht

How Can I Correctly Convert a DataTable to a CSV File in C#?

Effiziente Konvertierung von Datentabellen in CSV in C#

Dieser Artikel zeigt eine robuste Methode zum Konvertieren von C#-DataTable-Objekten in CSV-Dateien (Comma-Separated Value). Bei der ursprünglichen Methode gab es Probleme mit der ordnungsgemäßen Datentrennung. Diese Lösung bietet einen korrigierten und verbesserten Ansatz.

Hier ist der optimierte Code:

<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() ?? ""); //Handle null values
    sb.AppendLine(string.Join(",", fields));
}

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

Dieser Code behebt das ursprüngliche Problem, indem er die Daten innerhalb der CSV-Datei korrekt in einzelne Zellen aufteilt. Es nutzt die Methoden Select und string.Join von LINQ, um die durch Kommas getrennte Zeichenfolge sowohl für Spaltenüberschriften als auch für Datenzeilen effizient zu erstellen. Durch die Verwendung von File.WriteAllText wird sichergestellt, dass die CSV-Daten in die angegebene Datei geschrieben werden. Durch das Hinzufügen von field?.ToString() ?? "" werden potenzielle Nullwerte ordnungsgemäß behandelt.

Weitere Erweiterungen, wie z. B. Escape-Anführungszeichen für Sonderzeichen oder Speicheroptimierungstechniken, können je nach spezifischen Anwendungsanforderungen integriert werden.

Das obige ist der detaillierte Inhalt vonWie kann ich eine DataTable in C# korrekt in eine CSV-Datei konvertieren?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage