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
Lepaskan: 2024-12-03 02:51:14
asal
977 orang telah melayarinya

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;
}
Salin selepas log masuk

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!

sumber:php.cn
Kenyataan Laman Web ini
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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan