Mit diesem JavaScript-Snippet können Sie eine CSV-Zeichenfolge analysieren, die Kommas in den Daten enthält, während Kommas in Feldern in Anführungszeichen ignoriert werden:
const parseCSV = (csvString) => { const rows = csvString.split("\n"); const result = []; for (const row of rows) { const values = []; let currentField = ""; let inQuotes = false; for (const char of row) { if (char === '"' && currentField.length === 0) { inQuotes = !inQuotes; } else if (char === "," && !inQuotes) { values.push(currentField); currentField = ""; } else { currentField += char; } } if (currentField.length > 0) { values.push(currentField); } result.push(values); } return result; }; const csvString = 'string, duppi, du, 23, lala'; console.log(parseCSV(csvString));
Diese Lösung geht Ihre Probleme an Abfrage durch Verwendung einer zeichenweisen Prüfung der CSV-Zeichenfolge. Jedes Mal, wenn ein Komma erkannt wird und sich die Zeichenfolge nicht in einem Feld in Anführungszeichen befindet, wird ein neues Feld generiert. Wenn am Anfang eines Felds ein doppeltes Anführungszeichen steht, zeigt es den Anfang eines in Anführungszeichen gesetzten Felds an. Ein weiteres doppeltes Anführungszeichen außerhalb eines in Anführungszeichen gesetzten Felds kennzeichnet das Ende dieses Felds. Durch die ständige Überprüfung der Werte unterteilt diese Technik die CSV-Zeichenfolge präzise in einzelne Felder und berücksichtigt dabei die in Anführungszeichen gesetzten Bereiche.
Das obige ist der detaillierte Inhalt vonWie analysiere ich eine CSV-Zeichenfolge mit Kommas in zitierten Feldern in JavaScript?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!