Lösen Sie das Problem des Zusammenführens von Daten in einer einzelnen Zelle bei der Konvertierung von DataTable in CSV
Beim Exportieren einer DataTable in eine CSV-Datei können Benutzer auf ein Problem stoßen, bei dem die Daten nicht richtig getrennt sind, was dazu führt, dass alle Werte in der ersten Zelle jeder Zeile angezeigt werden. Um dieses Problem zu beheben, untersuchen wir den Code und identifizieren die zugrunde liegende Ursache.
Der Code erstellt zunächst ein StringBuilder-Objekt, durchläuft die Spalten der DataTable und generiert eine Kopfzeile mit durch Kommas getrennten Spaltennamen. Als Nächstes durchläuft es die Zeilen der DataTable, ruft den Wert jeder Spalte ab und hängt ihn an den StringBuilder an. Das Problem entsteht jedoch in der Art und Weise, wie die Daten getrennt werden.
Das Problem liegt im Hinzufügen der Daten zum Schleifenblock des StringBuilder. Die folgenden Codezeilen werden zum Trennen von Werten verwendet:
<code>sb.Append(row[i].ToString() + ",");</code>
Diese Codezeile fügt nach jedem Datenwert ein Komma zum StringBuilder hinzu. Wenn jedoch die Kommas am Ende jeder Zeile nicht entfernt werden, interpretiert Excel die Daten möglicherweise als einzelne Zellen und nicht als einzelne Werte.
Um dies zu beheben, entfernen Sie das abschließende Komma aus der letzten Iteration der inneren Schleife:
<code>for (int i = 0; i < dt.Columns.Count; i++) { sb.Append(row[i].ToString()); // 移除最后一次迭代的尾随逗号 if (i == dt.Columns.Count - 1) sb.Remove(sb.Length - 1, 1); else sb.Append(","); }</code>
Wenn Sie den Code auf diese Weise ändern, wird das abschließende Komma aus dem letzten Wert in jeder Zeile entfernt, sodass Excel die Daten ordnungsgemäß in einzelne Zellen aufteilen kann.
Das obige ist der detaillierte Inhalt vonWarum platziert meine DataTable-zu-CSV-Konvertierung alle Daten in einer einzigen Zelle und wie kann ich das Problem beheben?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!