我正在尝试解析 CSV。我想将它放入数据库中或只是用 JavaScript 解析它,但由于语法损坏,任何一种方法都失败了。我的整个 CSV 文件在这里:
https://gist.github.com/1023560

如果您注意到,它会在双引号中有双引号的地方中断,并且在插入 MySQL 时也会失败。第一个中断在第 13 行。它中断而不是返回完整的:

 <a href="http://www.facebook.com/pages/Portland-Community-Gardens/139244076118027?v=wall" target="_blank"><img src="/shared/cfm/image.cfm?id=348340" alt="Facebook" width="100" height="31" /></a>

它返回:
<a href="

对于 JavaScript,我将只使用 Ben Nadel 的 CSVToArray():
http://www.bennadel.com/blog/1504-Ask-Ben-Parsing-CSV-Strings-With-Javascript-Exec-Regular-Expression-Command.htm

我的最终目标是放入 MySQL,以便我可以使用 PHP 的 json_encode() 回显 JSON 提要。

我注意到可能有问题的事情是双引号可以像上面一样在 HTML 标签中,但也可以作为 HTML 标签的 textNodes,所以 "<span class="text">"Example"</span>"
第一组引号是 CSV 列,第二组是 HTML 引号,第三组是文本引号。

最佳答案

您可以欺骗它并使用正则表达式来查找:

"(.*?)"(?=,|$)

但这有点像hack-ish(基本上,只有在紧跟逗号或行尾时才接受结束引号)。相同的逻辑适用于查找替换。 (同样,这一切都假设“杂散”引用永远不会遵循标准的 CSV 规则(例如,在它之前或之后有一个逗号/行 [开始/结束]))

我假设您无法控制原始数据并且必须使用您拥有的数据?

编辑

虽然我只在你的数据的一小部分样本上尝试过这个,但这似乎找到了“杂散”引号,你可以使用 "" 替换:
(?<!^|"|,)"(?!"|,|$)

关于php - 损坏的 CSV,我该如何修复?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/6335811/

10-09 05:59
查看更多