json序列化後頁面顯示有反斜槓’\‘的問題

NO IMAGE

在做專案中,前臺傳來的資料為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-623153d64336,Name:王五,…“將得到的結果放在字典中:

<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>

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