C# 使用Newtonsoft.Json来读取JOSN数组

怎么在C#工程中安装Newtonsoft在这里就不提了,随便搜一下就有教程反正也是用NuGet包管理器安装。这里记录一下怎么读取JSON节点。

假如有如下JSON:

{
    "春哥": "纯爷们",
    "data": {
        "chun": 567890,
        "list": [
            {
                "id": "12345",
                "age": 5,
                "Job_number": 9049
            }
        ]
    }
}

刚开始学用这个Newtonsoft的时候别人的博客给出的演示例子是先声明一个类,然后实例化这个类,用访问类的数据成员的方式来访问JSON节点,这就比较麻烦了,Newtonsoft其实提供了直接把一整个JSON数据打包成一个JObject对象的方法,然后就可以像用类似数组的方式来访问这些节点。

首先导入支持库:

using Newtonsoft.Json;
using Newtonsoft.Json.Linq;
string content="{\"春哥\": \"纯爷们\",\"data\": {\"chun\": 567890,\"list\": [{\"id\": \"12345\",\"age\": 5,\"Job_number\": 9049}]}}"
JObject json = JObject.Parse(content);

//读取春哥节点
string enumGroupName = json["春哥"].ToString();
Console.WriteLine($"春哥:{enumGroupName}");

那么要怎么访问list这个数组呢?这个数组是JSON里比较常见的套娃数据,例:

string content="{\"春哥\": \"纯爷们\",\"data\": {\"chun\": 567890,\"list\": [{\"id\": \"12345\",\"age\": 5,\"Job_number\": 9049}]}}"
JObject json = JObject.Parse(content);

//虽然这个list数组里只有一个元素那也得写上索引
string enumGroupName = json["data"]["list"][0]["id"].ToString();
Console.WriteLine($"春哥:{enumGroupName}");

{
    "春哥": "纯爷们",
    "data": {
        "chun": 567890,
        "list": [
            {
                "id": "12343",
                "age": 3,
                "Job_number": 7039
            },

            {
                "id": "12347",
                "age": 4,
                "Job_number": 8029
            },

            {
                "id": "12340",
                "age": 5,
                "Job_number": 9089
            }
        ]
    }
}

如何遍历数组:

foreach (var item in json["data"]["list"])
{
    //遍历每一个{ }里的id节点
    Console.WriteLine(item["id"].ToString());

}

传统的for循环遍历:


var arrayProperty = (JArray)json["data"]["bet"];//获取数组长度
int length = arrayProperty.Count;

for (int i = 0; i < length; i++)
{
    string vernoru = json["data"]["list"][i]["match_id"].ToString();
    Console.WriteLine(vernoru);

}

  • 7
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在递归的数组中移除特定条件的属性,你可以使用递归函数来遍历`JObject`和`JArray`对象,并根据条件移除属性。以下是一个示例代码: ```csharp using Newtonsoft.Json.Linq; public static void RemoveProperties(JToken token, string propertyName) { if (token.Type == JTokenType.Object) { // 遍历对象属性 foreach (var child in token.Children<JProperty>().ToList()) { if (child.Name == propertyName) { // 移除满足条件的属性 child.Remove(); } else { // 递归处理子属性 RemoveProperties(child.Value, propertyName); } } } else if (token.Type == JTokenType.Array) { // 遍历数组元素 foreach (var child in token.Children().ToList()) { // 递归处理数组元素 RemoveProperties(child, propertyName); } } } // 示例用法 string json = @" { 'name': 'John', 'age': 30, 'children': [ { 'name': 'Alice', 'age': 5, 'children': [ { 'name': 'Bob', 'age': 10 } ] }, { 'name': 'Emma', 'age': 8 } ] }"; JObject obj = JObject.Parse(json); // 移除所有属性名为 "age" 的属性 RemoveProperties(obj, "age"); // 输出结果 Console.WriteLine(obj.ToString()); ``` 在上面的示例中,我们定义了一个递归函数`RemoveProperties`,该函数用于遍历`JObject`和`JArray`对象,根据条件移除属性。然后,我们使用这个函数移除了所有属性名为 "age" 的属性。最后,我们将修改后的`JObject`对象输出到控制台。 输出结果将不包含任何名为 "age" 的属性: ``` { "name": "John", "children": [ { "name": "Alice", "children": [ { "name": "Bob" } ] }, { "name": "Emma" } ] } ``` 希望这能满足你的需求!如果还有其他问题,请随时提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值