我正在尝试解析 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/