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!