0

如何"使用下面 JSON 字符串的正则表达式转义双引号内的双引号 ()?

[{
     "LDAP_ID":"a",
     "LAC_NO":"1153274",
     "ACTION":"VBE",
     "DATE_OF_ACTION":"06-01-2006 AM 12:00:00",
     "RESPONSE":"DPP",
     "DEF_OBSERV":"M",
     "REMARK":"visited b"         s emp & rcd 1 emi",
     "OPR_ID":"FCTV1",
     "ACTION_TO_BE":"",
     "ACTION_TO_BE_DT":"",
     "AMOUNT_TOBECHG":"",
     "DELEGATED_TO":"",
     "BRANCH_CODE":"100",
     "DISP_DATE_OF_ACTION":"06-JAN-06",
     "DISP_ACTION_TO_BE_DT":"",
     "SRNO":"142871",
     "DELETED_FLAG":"",
     "TIMESTAMP":"10-08-2012 AM 11:38:30",
     "STAMPDATETIME":"2012-08-10 11:38:30"
}]

需要转义的关键行:

"REMARK":"visited b"         s emp & rcd 1 emi",
4

2 回答 2

2

这个问题不能用正则表达式来解决。你甚至可以想出一个适用于 99% 的案例,但仅此而已。

无效 JSON 无效,必须由服务器端的人员修复。正则表达式并非旨在解决此类问题。你最好在服务器端修复它。

于 2012-09-18T07:43:07.760 回答
0

使用正则表达式修复 JS 中无效 JSON 的唯一方法是将其作为字符串接收,进行替换,然后将其重新评估为 JSON。最后一步可能不安全。这是一个类似问题的问题:Convert object string to JSON

所以我建议在收到 JSON 之前修复它。无论如何,如果你不能,这里有一个正则表达式的解决方案。

正则表达式仅在值的分隔符之间操作:" 和 ",以确保仅转义值中的双引号(已编辑)。

:\s*"[^"]*"[^"]*"\s*(,|\s*\})

这是替换的完整代码(正则表达式编辑):

var str = '[{ "LDAP_ID":"a", "LAC_NO":"1153274", "ACTION":"VBE", "DATE_OF_ACTION":"06-01-2006 AM 12:00:00", "RESPONSE":"DPP", "DEF_OBSERV":"M", "REMARK":"visited b" s emp & rcd 1 emi", "OPR_ID":"FCTV1", "ACTION_TO_BE":"", "ACTION_TO_BE_DT":"", "AMOUNT_TOBECHG":"", "DELEGATED_TO":"", "BRANCH_CODE":"100", "DISP_DATE_OF_ACTION":"06-JAN-06", "DISP_ACTION_TO_BE_DT":"", "SRNO":"142871", "DELETED_FLAG":"", "TIMESTAMP":"10-08-2012 AM 11:38:30", "STAMPDATETIME":"2012-08-10 11:38:30" }]'

var j = str.replace(/(:\s*"[^"]*)"([^"]*"\s*(,|\s*\}))/g, '$1\\"$2');

var json = JSON.stringify(eval("(" + j + ")"));
于 2012-09-18T07:36:26.070 回答