C# JArray與JObject 的使用
STEP1、using Newtonsoft.Json.Linq;
STEP2 如何獲取json里的某個屬性(節點)值,對其刪改,新增
//2.1 數組用JArray加載 string jsonText = "[{'a':'aaa','b':'bbb','c':'ccc'},{'a':'aa','b':'bb,'c':'cc'}]"; var mJObj = JArray.Parse(jsonText t); //需求,刪除列表里的a節點的值為'aa'的項 IList<JToken> delList = new List<JToken>(); //存儲需要刪除的項 foreach (var ss in mJObj ) //查找某個字段與值 { if(((JObject) ss)["a"]=='aa') delList .add(ss); } foreach (var item in delList ) //移除mJObj 在delList 里的項 { mJObj .remove(item); } //2.2 非數組用JObject加載 (這里主要以這個為例子) string jsonText = "[{'a':'aaa','b':'bbb','c':'ccc'}]"; var mJObj = JObject.Parse(jsonText t); mJObj.Add() //新增,沒試過 var v1=mJObj[a].ToString() //得到'aaa'的值
以上的例子可交互靈活使用
注意事項,JArray 只能用來查找索引的項的對象,找到對象需要轉換為 JObject,再查找對應的屬性值
其他寫法補充
1、屬性下嵌套json (非數組)遍歷其包含的屬性列表
var xx = ((mJObj["dim"])).Children().Values();
foreach (var item in xx)
{
var dimID = ((JObject) item)["id"];
}