解析json字符串有很多方式, 1 : 在网上下载json解析的dll类库并添加引用, 调用相关方法; 2 : 使用自带类库JavaScriptSerializer的序列号和反序列化; 对于以上两个方法我没有试用过, 应该很方便很简洁性能很高吧!
自己根据遍历字符串找json字符串规律, 自己写了一个类库, 只有一个方法只提供解析, 没有其他方法. 缺点 : 可能比较死板, 可能性能也不及网上下载解析类库.
经测试和调试后可以遍历大部分json字符串数据, json字符串可以嵌套, 但要符合json的规律, 数据中不能出现json字符串敏感关键字符 " 和 , 和 [ ] 和 { } ,数据中如果需要使用可以使用中文字符代替.
数据返回结果存放在 Dictionary<string, object> 键 值对中, 如果 值为字符串, 那么object就为字符串,为了嵌套, 如果 值为数组, 那么object就为 List<object> , 如果值为一个对象, 那么object就存放在 Dictionary<string, object> 如此嵌套下去, 最终数据我们根据自己的json数据结构遍历Dictionary<string, object>集合即可. (注 : 每个Dictionary中键必须唯一)
1. 解析类 : AnalyzeJSON 全部代码:
using System; using System.Collections.Generic; using System.Linq; using System.Text; namespace System.AnalyzeJSON { /// <summary> /// 对于 JSON数据进行解析 /// Date:2019/6/25 /// Author:weloglog /// </summary> public class AnalyzeJSON { /// <summary> /// 最大嵌套深度 /// </summary> public int MaxNum = 50; /// <summary> /// 解析JSON字符串 /// </summary> /// <param name="strJSON">JSON字符串</param> /// <returns>返回Dictionary数据</returns> public Dictionary<string, object> AnalyzeString(string strJSON) { if (strJSON == null || strJSON.Trim() == "" || strJSON.Trim().Length < 0) { return null; } #region 筛选判断并赋值 [此步骤可以省略] int idF = -1;//第一个 { 下标索引 int idL = -1;//最后一个 } 下标索引 int mD = 0;//记录 { } 的个数对 int mZ = 0;//记录 [ ] 的个数对 for (int i = 0; i < strJSON.Length; i++) { if (mD > MaxNum || mZ > MaxNum) { break;//不满足条件退出循环 } if (idF == -1 && strJSON[i] == '{') { idF = i;//取第一个 { 下标 } if (strJSON[i] == '{') { mD++; if (idL > 0) { break; } } if (strJSON[i] == '}') { mD--; if (mD == 0) { idL = i; } } if (strJSON[i] == '[') { mZ++; } if (strJSON[i] == ']') { mZ--; } } if (mD == 0 && mZ == 0 && idL > 0 && idL - idF > 1) { strJSON = strJSON.Substring(idF, idL - idF + 1);//重新赋值json字符串数据, 去掉{ }前后多余部分 } else { return null;//条件不满足, JSON字符串不规范 } #endregion //遍历 并返回 return obj(strJSON); } //遇到 { } 的处理函数 private Dictionary<string, object> obj(string str) { Dictionary<string, object> ro = new Dictionary<string, object>(); int dc = 0;//{ } 的对数 int len = str.Length; for (int i = 0; i < len; i++) { if (str[i] == '{') { dc++; } if (str[i] == '}') { dc--; } if (str[i] != '{' && dc > 0) { StringBuilder tem = new StringBuilder(); StringBuilder ojtem = new StringBuilder(); bool isstr = false; object oj = ""; int c = 0;//次数 bool iskey = true;//是否为键赋值 bool isString = true;//值是否为字符串类型 while (i < len && str[i] != ',') { if (iskey) //给键 赋值 { if (str[i] != '\"') { if (str[i] == ':') { iskey = false; c = -1;//重置 } else { //tem += str[i]; tem.Append(str[i]); } } } else //给值 赋值 { //特殊情况, 遇到 { } 和 [ ] 的情况 if (isString && str[i] == '[')//只允许第一次进入 { isString = false; int idxs = 0;//记录 [ ] 出现的次数 StringBuilder tm = new StringBuilder(); while (i < len) { if (str[i] == '[') { idxs++; } if (str[i] == ']') { idxs--; } tm.Append(str[i]); i++; if (idxs == 0)//变成一个完整的组合 { break; } } oj = arr(tm.ToString()); break; } else if (isString && str[i] == '{')//只允许第一次进入 { isString = false; int idxs = 0;//记录 { } 出现的次数 StringBuilder tm = new StringBuilder(); while (i < len) { if (str[i] == '{') { idxs++; } if (str[i] == '}') { idxs--; } tm.Append(str[i]); i++; if (idxs == 0)//变成一个完整的组合 { break; } } oj = obj(tm.ToString()); break; } else { if (str[i] != '\"') { if (str[i] == ',' || str[i] == '}' || str[i] == ']')//跳出循环 { break; } else { isstr = true; ojtem.Append(str[i]); } } } } c++; i++; } c = 0; try//键 唯一 { if (tem != null && tem.ToString().Length > 0) { if (isstr) { ro.Add(tem.ToString(), ojtem);//添加 isstr = false; } else { ro.Add(tem.ToString(), oj);//添加 } } } catch { } } } return ro; } //遇到 [ ] 的处理函数 private object arr(string str) { object ojj = new object(); //去掉首位 [ ] 符号 str = str.Substring(1, str.Length - 2); int len = str.Length; int c = 0;//双引号索引 List<object> lst = new List<object>(); bool ists = false;//是否为特殊 for (int i = 0; i < len; i++) { object tem = ""; StringBuilder sb = new StringBuilder(); bool isstr = false; while (i < len) { if (str[i] == '[')//特殊处理 { int idxs = 0;//记录 [ ] 出现的次数 StringBuilder tm = new StringBuilder(); while (i < len) { if (str[i] == '[') { idxs++; } if (str[i] == ']') { idxs--; } tm.Append(str[i]); i++; if (idxs == 0)//变成一个完整的组合 { break; } } lst.Add(arr(tm.ToString())); ists = true; i++; continue; } else if (str[i] == '{')//特殊处理 { int idxs = 0;//记录 [ ] 出现的次数 StringBuilder tm = new StringBuilder(); while (i < len) { if (str[i] == '{') { idxs++; } if (str[i] == '}') { idxs--; } tm.Append(str[i]); i++; if (idxs == 0)//变成一个完整的组合 { break; } } lst.Add(obj(tm.ToString())); ists = true; i++; continue; } else { ists = false; if (c == 0 && str[i] == '\"') { i++; c++; continue; } if (str[i] == '\"' && i + 1 < len && str[i + 1] == ',' || i + 1 == len) { i++; c++; break; } if (str[i] == '\"' && i + 1 < len && str[i + 1] == ']' || i + 1 == len) { i++; c++; continue; } if (i + 1 < len && str[i + 1] == ']') { i++; c++; continue; } isstr = true; sb.Append(str[i]); i++; c++; } } if (!ists) { if (isstr) { lst.Add(sb);// [ ] 的值存入List<string> 中 isstr = false; } else { lst.Add(tem);// [ ] 的值存入List<string> 中 } } c = 0;//归零 } ojj = lst; return ojj; } } }