>웹 프론트엔드 >JS 튜토리얼 >JavaScript에서 쉼표가 있는 CSV 문자열을 올바르게 구문 분석하는 방법은 무엇입니까?

JavaScript에서 쉼표가 있는 CSV 문자열을 올바르게 구문 분석하는 방법은 무엇입니까?

Linda Hamilton
Linda Hamilton원래의
2024-12-03 02:51:14971검색

How to Correctly Parse CSV Strings with Commas in JavaScript?

JavaScript에서 문자열을 구문 분석할 때 CSV 데이터의 쉼표를 처리하는 방법

쉼표도 포함된 데이터가 포함된 CSV 문자열을 처리할 때 구문 분석을 통해 까다로워. 일부 값이 따옴표로 묶인 경우 문자열을 쉼표(",")로만 분할하면 원하는 출력이 제공되지 않습니다. 따옴표를 존중하면서 이러한 CSV 문자열을 구문 분석하는 방법은 다음과 같습니다.

// Regex to validate a CSV string:
const re_valid = /^\s*(?:'[^'\]*(?:\[\S\s][^'\]*)*'|"[^"\]*(?:\[\S\s][^"\]*)*"|[^,'"\s\]*(?:\s+[^,'"\s\]+)*)\s*(?:,\s*(?:'[^'\]*(?:\[\S\s][^'\]*)*'|"[^"\]*(?:\[\S\s][^"\]*)*"|[^,'"\s\]*(?:\s+[^,'"\s\]+)*)*\s*)*$/;

// Regex to parse one value from a valid CSV string:
const re_value = /(?!\s*$)\s*(?:'([^'\]*(?:\[\S\s][^'\]*)*)'|"([^"\]*(?:\[\S\s][^"\]*)*)"|([^,'"\s\]*(?:\s+[^,'"\s\]+)*)|)\s*(?:,|$)/g;

function CSVtoArray(text) {
    if (!re_valid.test(text)) return null;
    const a = [];
    text.replace(re_value, (m0, m1, m2, m3) => {
        if      (m1 !== undefined) a.push(m1.replace(/\'/g, "'"));
        else if (m2 !== undefined) a.push(m2.replace(/\"/g, '"'));
        else if (m3 !== undefined) a.push(m3);
        return '';
    });
    if (/,\s*$/.test(text)) a.push('');
    return a;
}

이 접근 방식을 사용하면 따옴표를 존중하면서 혼합 유형 및 이스케이프 문자가 포함된 CSV 문자열을 포함하여 CSV 문자열을 정확하게 구문 분석할 수 있습니다.

위 내용은 JavaScript에서 쉼표가 있는 CSV 문자열을 올바르게 구문 분석하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.