C# 检测JToken中的连续花括号
下面我用C# 检测JToken中的连续花括号,c#,C#,下面我用JToken 项目价值 {“子句类型”:[ “不可抗力-概述” ]} 上述值和代码工作正常。。但有时该值有一个连续的花括号 {{“子句类型”:[ “不可抗力-概述” ]}} 反序列化时,它会导致错误无效的属性标识符字符:{.Path',第1行,位置1 如果项有一个连续的花括号,有没有办法删除或检查该项,并将其删除?正如@00110001在评论中指出的那样,建议首先修复json。但是如果没有,您可以使用此正则表达式将两个或多个连续的花括号替换为一个: string new_item = R
JToken
项目价值
{“子句类型”:[
“不可抗力-概述”
]}
上述值和代码工作正常。。但有时该值有一个连续的花括号
{{“子句类型”:[
“不可抗力-概述”
]}}
反序列化时,它会导致错误无效的属性标识符字符:{.Path',第1行,位置1
如果
项有一个连续的花括号,有没有办法删除或检查该项
,并将其删除?正如@00110001在评论中指出的那样,建议首先修复json。但是如果没有,您可以使用此正则表达式将两个或多个连续的花括号替换为一个:
string new_item = Regex.Replace(Regex.Replace(Item, "([{][{]+)" ,"{"), "([}][}]+)" , "}");
在json的源代码处修复json,而不是尝试解析无效的JSONI如果您想避免使用正则表达式,那么可以使用while(!string.IsNullOrWhiteSpace(item)&&item.Trim().IndexOf(“{”,0)!=-1)item=新字符串(item.Skip(1.ToArray())
它只处理字符串的开头,其余部分也必须实现。谢谢,它是有效的。但是你能解释一下正则表达式吗?即使我研究了多少次,我也看不懂正则表达式
string new_item = Regex.Replace(Regex.Replace(Item, "([{][{]+)" ,"{"), "([}][}]+)" , "}");