终于用正则表达式一步完美处理了Json数据里的存在单引号/双引号导致解析失败的报错,这样无论什么开发语言,都可以搞定这个问题了。
Uncaught SyntaxError: JSON.parse: expected ',' or '}' after property value in object at line 1 column 41 of the JSON data
我的json数据原文如下:
var responseData = '{"Rows01":[{"DS2001":"21","DS2004":"Sun"s Co.,Ltd"}]}';
可以看到,DS2004的值中有双引号",其实是数据来着,影响了我的json解析,导致解析失败。
使用以下正则表达式进行转义:
(?<=([^{:,]))(")(?=([^}:,]))
完整测试示例如下:
//后台返回的json数据
var responseData = '{"Rows01":[{"DS2001":"21","DS2004":"Sun"s Co.,Ltd"}]}';
//使用正则转义双引号
var escapedResponseData = responseData.replace(/(?<=([^{:,]))(")(?=([^}:,]))/g, "\\\"");
//json字符串转成json对象
var jsonData = JSON.parse(escapedResponseData);
//控制台打印Rows01对象的值
console.log(jsonData.Rows01);
这个时候,无论你用什么语言,都可以使用这个正则表达式一步替换,对有这样异常的数据进行修正了。
当然,现实中还有其他的各种特殊情况,复杂多变,肉眼可见的格式错乱,但是程序不一定能100%解决。有其他特殊情况,欢迎在评论区留言沟通。
---------------------------------------
补充:
如果引号附近有空格,可以这样修改:
?(?<!(\s*[{:,]\s*))(\")(?!(\s*[}:,]\s*))? ==替换==>? \"
?