Rumah >hujung hadapan web >tutorial js >Bagaimana Menghuraikan Rentetan CSV dengan Koma dalam JavaScript dengan betul?

Bagaimana Menghuraikan Rentetan CSV dengan Koma dalam JavaScript dengan betul?

Linda Hamilton
Linda Hamiltonasal
2024-12-03 02:51:14971semak imbas

How to Correctly Parse CSV Strings with Commas in JavaScript?

Cara Mengendalikan Koma dalam Data CSV Apabila Menghuraikan Rentetan dalam JavaScript

Apabila berurusan dengan rentetan CSV yang mengandungi data yang juga termasuk koma, penghuraian boleh menjadi rumit. Memisahkan rentetan pada koma (",") sahaja tidak akan memberikan anda output yang diingini jika beberapa nilai disertakan dalam tanda petikan. Begini cara anda boleh menghuraikan rentetan CSV sedemikian sambil menghormati tanda petikan:

// 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;
}

Dengan pendekatan ini, anda boleh menghuraikan rentetan CSV dengan tepat, termasuk yang mempunyai jenis bercampur dan aksara yang terlepas, sambil menghormati tanda petikan.

Atas ialah kandungan terperinci Bagaimana Menghuraikan Rentetan CSV dengan Koma dalam JavaScript dengan betul?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn