当前位置: 首页 > 知识库问答 >
问题:

csv数据基于逗号分割,但使用双引号或任何括号忽略

马冯浩
2023-03-14

我需要解析一个。csv文件,并根据逗号分割字段,但应忽略双引号或任何括号内的逗号。以下是我的数据片段。

"263P", "12 KMS","http://www.someurl.com/color?width=10&height=70&iframe=true","[{"stop": "abc, def, A.B.C", "latlons": ["13.0455367265411", "77.5055545144687"]}]", "08:35,09:55,11:40", "13:00,  14:20,  15:40,  17:25"

我已经尝试了在stackoverflow上建议的许多选项,但这些都不适合我的数据。

其中一个非常接近匹配的正则表达式

str.match(/(".*?"|[^,]+)(?=,|$)/g);

但它在双引号内无法正常工作

共有1个答案

仲孙兴旺
2023-03-14

我可以为我自己的问题建立正则表达式,所以在这里发布解决方案

str.match(/(“[.?]”|".?"|".*?"\r |[^”,](?=,|$)/g)

有了这个正则表达式,我可以根据逗号分隔所有csv单元格(在引号内忽略)。

 类似资料:
  • 输入字符串用逗号分隔。但它可能包含双引号内的逗号,需要忽略。下面是示例字符串 下面是我用来拆分逗号的代码,但如果逗号是双引号中字符串的一部分,它就会失败。 所以任何解决这个问题的想法。

  • 问题内容: 我有一些输入如下所示: 逗号分隔的值可以是任何顺序。我想用逗号分割字符串;但是,在双引号内包含某些内容的情况下,我需要它既忽略逗号又去除引号(如果可能)。因此,基本上,输出将是以下字符串列表: 我已经看过其他一些答案,并且我认为正则表达式是最好的,但是我想出这些答案很糟糕。 问题答案: 拉瑟是对的。这是一个逗号分隔的值文件,因此您应该使用module。一个简单的例子:

  • 问题内容: 我有一个像这样的字符串: 上面的字符串应分为: 问题答案: 我认为最简单的解决方案是处理输入字符串char-by-char: 例: 作为免费赠品,此解决方案还根据需要计算嵌套括号: 它还检查括号是否平衡(每个开放的括号都有相应的结束符)。

  • 问题内容: 我正在寻找将其转换为6个元素的数组:a,b,c,“ d,e,f”,g,h。我正在尝试通过Javascript执行此操作。这是我到目前为止所拥有的: 但是现在,它会将双引号中的所有内容都分割开了,这是不正确的。 编辑:好的,抱歉,我对这个问题的措辞很差。给我一个字符串而不是数组。 我想使用“ split”功能将 其 转换为数组。 问题答案: 这就是我要做的。

  • 问题内容: 我有一个模糊的字符串,像这样: 我想按逗号分割-但我需要忽略引号中的逗号。我怎样才能做到这一点?似乎正则表达式方法失败了;我想我可以在看到报价时手动扫描并进入其他模式,但是使用预先存在的库会很好。(编辑:我想我的意思是那些已经属于JDK或已经属于诸如Apache Commons之类的常用库的库。) 上面的字符串应分为: 注意:这不是CSV文件,它是文件中包含的单个字符串,具有较大的整体

  • 问题内容: 我有这样一个字符串: 我想按逗号分割-但我需要忽略引号中的逗号。我怎样才能做到这一点?似乎正则表达式方法失败了;我想我可以在看到报价时手动扫描并进入其他模式,但是使用预先存在的库会很好。 上面的字符串应分为: 问题答案: 可以使用正则表达式 输出: