首页 > web前端 > js教程 > 正则表达式如何解决JavaScript中数据字段中带逗号的CSV字符串解析问题?

正则表达式如何解决JavaScript中数据字段中带逗号的CSV字符串解析问题?

DDD
发布: 2024-12-07 04:14:10
原创
264 人浏览过

How Can Regular Expressions Solve the Problem of Parsing CSV Strings with Commas in Data Fields in JavaScript?

JavaScript 中可解析的 CSV 字符串

解析数据中带逗号的 CSV

在这种情况下,您需要一个解决方案来区分引号内的逗号与那些分隔值。正则表达式是完成此任务的理想工具。解决方法如下:

正则表达式解决方案

  1. 定义 CSV 字符串结构: 确定有效 CSV 字符串的特征,包括带引号的字符串,转义字符和数据格式。
  2. CSV 的正则表达式验证: 创建一个正则表达式来验证给定字符串是否满足这些条件。
  3. 用于值提取的正则表达式: 构造一个正则表达式以匹配并从有效的 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 to parse CSV string into array
const CSVtoArray = (text) => {
  // Validate CSV string
  if (!re_valid.test(text)) return null;

  const values = [];

  text.replace(re_value, (m0, m1, m2, m3) => {
    // Handle single-quoted values
    if (m1 !== undefined) values.push(m1.replace(/\'/g, "'"));

    // Handle double-quoted values
    else if (m2 !== undefined) values.push(m2.replace(/\"/g, '"'));

    // Handle unquoted values
    else if (m3 !== undefined) values.push(m3);

    return '';
  });

  // Handle special case of empty last value
  if (/,\s*$/.test(text)) values.push('');

  return values;
};
登录后复制

示例用法

// Sample CSV string with commas in data
const csvString = "'string, with comma', 23, 'lala'";

// Parse the CSV string into an array of values
const values = CSVtoArray(csvString);

console.log(values); // ['string, with comma', '23', 'lala']
登录后复制

此方法有效地解析 CSV 字符串,保留引用值的完整性并正确处理逗号在数据字段内。您可以调整正则表达式来自定义特定 CSV 字符串变体或格式要求的处理。

以上是正则表达式如何解决JavaScript中数据字段中带逗号的CSV字符串解析问题?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板