如何去掉Json字符串中反斜杠
Posted 邱慕夏
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何去掉Json字符串中反斜杠相关的知识,希望对你有一定的参考价值。
做项目的时候,遇到了这样的问题,前台传来的Json字符串在实体类中不对应(无法转换为实体类),而且传来的数据项是跟着数据库中的表的变动而变动的(不能重写实体类)。
前台Json字符串为:
string s1 ="[\\"ID\\":\\"99d2a341-ea2e-4f04-b4f4-623153d64336\\",\\"Name\\":\\"王五\\",\\"TotalScores\\":80,\\"工作效率\\":\\"B\\",\\"职业道德\\":\\"B\\",\\"业务能力\\":\\"A\\",\\"链接自律\\":\\"B\\",\\"工作成绩\\":\\"B\\",\\"ID\\":\\"728f72ac-473b-4bde-bf83-7ed93d3fd9e6\\",\\"Name\\":\\"李四\\",\\"TotalScores\\":80,\\"工作效率\\":\\"B\\",\\"职业道德\\":\\"B\\",\\"业务能力\\":\\"A\\",\\"链接自律\\":\\"B\\",\\"工作成绩\\":\\"B\\",\\"ID\\":\\"29c80443-d0ac-414c-91b5-acd5e69e28f2\\",\\"Name\\":\\"刘七\\",\\"TotalScores\\":80,\\"工作效率\\":\\"B\\",\\"职业道德\\":\\"B\\",\\"业务能力\\":\\"A\\",\\"链接自律\\":\\"B\\",\\"工作成绩\\":\\"B\\"]";
可以看到其实在微软中将“\\“”作为双引号用的,思路是这样的:
1、去掉“\\“”
代码实现:
strings11=s1.Replace("\\"","");
2、去掉”[]“
代码实现:
string s22 =s11.Replace("[","");
string s33 =s22.Replace("]", "");
这是时候我们得到的s33是这样的:
s33="ID:99d2a341-ea2e-4f04-b4f4-623153d64336,Name:王五,TotalScores:80,工作效率:B,职业道德:B,业务能力:A,链接自律:B,工作成绩:B,ID:728f72ac-473b-4bde-bf83-7ed93d3fd9e6,Name:李四,TotalScores:80,工作效率:B,职业道德:B,业务能力:A,链接自律:B,工作成绩:B,ID:29c80443-d0ac-414c-91b5-acd5e69e28f2,Name:刘七,TotalScores:80,工作效率:B,职业道德:B,业务能力:A,链接自律:B,工作成绩:B"
3、将”,“调换为”“,去掉空值
代码实现:
string s44 =s33.Replace(",","");
s44="ID:99d2a341-ea2e-4f04-b4f4-623153d64336,Name:王五,TotalScores:80,工作效率:B,职业道德:B,业务能力:A,链接自律:B,工作成绩:BID:728f72ac-473b-4bde-bf83-7ed93d3fd9e6,Name:李四,TotalScores:80,工作效率:B,职业道德:B,业务能力:A,链接自律:B,工作成绩:BID:29c80443-d0ac-414c-91b5-acd5e69e28f2,Name:刘七,TotalScores:80,工作效率:B,职业道德:B,业务能力:A,链接自律:B,工作成绩:B"
string[] s55s =s44.Split(new Char[] '', '' , StringSplitOptions.RemoveEmptyEntries);
s55s是得到的”ID:99d2a341-ea2e-4f04-b4f4-623153d64336,Name:王五,...“将得到的结果放在字典中:
<span style="font-size:18px;"><span style="font-size:18px;"> for (int i = 0; i < updatedEdit.Length; i++)
//string[] detailevaluationinfo = updatedEdit[i].Split(',');
string pat = @"(?<key>[^,:\\s]*):(?<value>[^,:\\s]*)";
//一组之间的数据拿出来
//for (int j = 0; j < detailevaluationinfo.Length; j++)
MatchCollection matches = Regex.Matches(updatedEdit[i], pat);
Dictionary<string, string> dict = new Dictionary<string, string>();
foreach (Match m in matches)
if (dict.ContainsKey(m.Groups["key"].Value)) continue;//不能重复啊
dict.Add(m.Groups["key"].Value, m.Groups["value"].Value);
</span></span>
这样就可以将Json字符串截取出来。
完整代码:
<span style="font-size:18px;"> private static void TestRegex20()
string s1 = "[\\"ID\\":\\"99d2a341-ea2e-4f04-b4f4-623153d64336\\",\\"Name\\":\\"王五\\",\\"TotalScores\\":80,\\"工作效率\\":\\"B\\",\\"职业道德\\":\\"B\\",\\"业务能力\\":\\"A\\",\\"链接自律\\":\\"B\\",\\"工作成绩\\":\\"B\\",\\"ID\\":\\"728f72ac-473b-4bde-bf83-7ed93d3fd9e6\\",\\"Name\\":\\"李四\\",\\"TotalScores\\":80,\\"工作效率\\":\\"B\\",\\"职业道德\\":\\"B\\",\\"业务能力\\":\\"A\\",\\"链接自律\\":\\"B\\",\\"工作成绩\\":\\"B\\",\\"ID\\":\\"29c80443-d0ac-414c-91b5-acd5e69e28f2\\",\\"Name\\":\\"刘七\\",\\"TotalScores\\":80,\\"工作效率\\":\\"B\\",\\"职业道德\\":\\"B\\",\\"业务能力\\":\\"A\\",\\"链接自律\\":\\"B\\",\\"工作成绩\\":\\"B\\"]";
//去掉反义字符串
string s11 = s1.Replace("\\"", "");
string s22 = s11.Replace("[", "");
string s33 = s22.Replace("]", "");
//s33——"ID:99d2a341-ea2e-4f04-b4f4-623153d64336,Name:王五,TotalScores:80,工作效率:B,职业道德:B,业务能力:A,链接自律:B,工作成绩:B,ID:728f72ac-473b-4bde-bf83-7ed93d3fd9e6,Name:李四,TotalScores:80,工作效率:B,职业道德:B,业务能力:A,链接自律:B,工作成绩:B,ID:29c80443-d0ac-414c-91b5-acd5e69e28f2,Name:刘七,TotalScores:80,工作效率:B,职业道德:B,业务能力:A,链接自律:B,工作成绩:B"
string s44 = s33.Replace(",", "");
//s44——"ID:99d2a341-ea2e-4f04-b4f4-623153d64336,Name:王五,TotalScores:80,工作效率:B,职业道德:B,业务能力:A,链接自律:B,工作成绩:BID:728f72ac-473b-4bde-bf83-7ed93d3fd9e6,Name:李四,TotalScores:80,工作效率:B,职业道德:B,业务能力:A,链接自律:B,工作成绩:BID:29c80443-d0ac-414c-91b5-acd5e69e28f2,Name:刘七,TotalScores:80,工作效率:B,职业道德:B,业务能力:A,链接自律:B,工作成绩:B"
string[] s55s = s44.Split(new Char[] '', '' , StringSplitOptions.RemoveEmptyEntries);
for (int i = 0; i < s55s.Length; i++)
//string[] detailevaluationinfo = updatedEdit[i].Split(',');
string pat = @"(?<key>[^,:\\s]*):(?<value>[^,:\\s]*)";
//一组之间的数据拿出来
//for (int j = 0; j < detailevaluationinfo.Length; j++)
MatchCollection matches = Regex.Matches(s55s[i], pat);
Dictionary<string, string> dict = new Dictionary<string, string>();
foreach (Match m in matches)
if (dict.ContainsKey(m.Groups["key"].Value)) continue;//不能重复啊
dict.Add(m.Groups["key"].Value, m.Groups["value"].Value);
</span>
以上是关于如何去掉Json字符串中反斜杠的主要内容,如果未能解决你的问题,请参考以下文章