如何去掉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,工作成績: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[] s55s =s44.Split(new Char[] { '}', '{' }, StringSplitOptions.RemoveEmptyEntries);


s55s是得到的”ID:99d2a341-ea2e-4f04-b4f4-623153d64336Name:王五,...“將得到的結果放在字典中:


[csharp] view plain copy
print ?
  1. <span style="font-size:18px;"><span style="font-size:18px;">  for (int i = 0; i < updatedEdit.Length; i++) {  
  2.                     //string[] detailevaluationinfo = updatedEdit[i].Split(',');  
  3.                     string pat = @"(?<key>[^,:\s]*):(?<value>[^,:\s]*)";  
  4.                     //一組之間的數據拿出來  
  5.                     //for (int j = 0; j < detailevaluationinfo.Length; j++) {  
  6.                     MatchCollection matches = Regex.Matches(updatedEdit[i], pat);  
  7.                         Dictionary<stringstring> dict = new Dictionary<stringstring>();  
  8.                         foreach (Match m in matches)  
  9.                         {  
  10.                             if (dict.ContainsKey(m.Groups["key"].Value)) continue;//不能重復啊  
  11.                             dict.Add(m.Groups["key"].Value, m.Groups["value"].Value);  
  12.                         }  
  13.   
  14. }</span></span>  




這樣就可以將Json字符串截取出來。


完整代碼:


[csharp] view plain copy
print ?
  1. <span style="font-size:18px;">      private static void TestRegex20()  
  2.         {  
  3.             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\"}]";  
  4.   
  5.             //去掉反義字符串  
  6.             string s11 = s1.Replace("\"""");  
  7.             string s22 = s11.Replace("[""");  
  8.             string s33 = s22.Replace("]""");  
  9.             //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}"  
  10.   
  11.             string s44 = s33.Replace("},{""}");  
  12.             //s44——"{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}"  
  13.   
  14.             string[] s55s = s44.Split(new Char[] { '}''{' }, StringSplitOptions.RemoveEmptyEntries);  
  15.   
  16.   
  17.             for (int i = 0; i < s55s.Length; i++)  
  18.             {  
  19.                 //string[] detailevaluationinfo = updatedEdit[i].Split(',');  
  20.                 string pat = @"(?<key>[^,:\s]*):(?<value>[^,:\s]*)";  
  21.                 //一組之間的數據拿出來  
  22.                 //for (int j = 0; j < detailevaluationinfo.Length; j++) {  
  23.                 MatchCollection matches = Regex.Matches(s55s[i], pat);  
  24.                 Dictionary<stringstring> dict = new Dictionary<stringstring>();  
  25.                 foreach (Match m in matches)  
  26.                 {  
  27.                     if (dict.ContainsKey(m.Groups["key"].Value)) continue;//不能重復啊  
  28.                     dict.Add(m.Groups["key"].Value, m.Groups["value"].Value);  
  29.                 }  
  30.             }  
  31.         }</span>  


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM