Heim >Web-Frontend >js-Tutorial >Wie analysiere ich eine CSV-Zeichenfolge mit Kommas in zitierten Feldern in JavaScript?

Wie analysiere ich eine CSV-Zeichenfolge mit Kommas in zitierten Feldern in JavaScript?

DDD
DDDOriginal
2024-12-03 00:27:15335Durchsuche

How to Parse a CSV String with Commas Inside Quoted Fields in JavaScript?

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!

Stellungnahme:
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