C# 中的 JSON 字符串到模型/HashMap/字典

san*_*ive 4 c# json dictionary hashmap

我有 JSON:

{
"One": [
{
  "ID": 1,
  "name": "s"
},
{
  "categoryID": 2,
  "name": "c"
}
],
"Two": [
{
  "ID": 3,
  "name": "l"
}
],
"Three": [
{
  "ID": 8,
  "name": "s&P"
},
{
  "ID": 52,
  "name": "BB"
}
]
}
Run Code Online (Sandbox Code Playgroud)

我想要:

  1. 将此 JSON 带到任何对象(如 JObject)

  2. 根据不同条件过滤 JSON(例如名称以 s 开头等)

  3. 返回此 JSON 给客户端

我尝试过的事情:1.创建模型:

class Model
{
public int Id;
public string name;
}
class MainModel
{
public string mainName;
public List<Model> categories;
}
Run Code Online (Sandbox Code Playgroud)

并使用这些模型来:

List<MainModel> m = json_serializer.DeserializeObject(jsonString);
Run Code Online (Sandbox Code Playgroud)
  1. 我也尝试过字典,但无法抛出异常。

任何帮助,将不胜感激。

小智 6

下面将允许您将 JSON 反序列化为字典并对其进行过滤。这使用 Newtonsoft.Json Nuget 包,但这相当常见。代码贴在下面。工作示例在这里找到.Net Fiddle

using System;
using Newtonsoft.Json;
using System.Collections.Generic;
using System.Linq;


public class Program
{
    public static void Main()
    {
        var json = "{\"One\": [{  \"ID\": 1,  \"name\": \"s\"},{  \"categoryID\": 2,  \"name\": \"c\"}],\"Two\": [{  \"ID\": 3,  \"name\": \"l\"}],\"Three\": [{  \"ID\": 8,  \"name\": \"s&P\"},{  \"ID\": 52,  \"name\": \"BB\"}]}";      
        var deserialized = JsonConvert.DeserializeObject<Dictionary<string, List<Model>>>(json);

        Console.WriteLine(deserialized["One"][0].name);

        Console.WriteLine("Filter to starts with s");
        var filtered = deserialized.SelectMany(item => item.Value).Where(innerItem => innerItem.name.StartsWith("s"));
        foreach(var item in filtered){
            Console.WriteLine(item.name);   
        }

    }

    public class Model{
        public int ID {get;set;}
        public string name {get;set;}
        public int categoryID {get;set;}
    }
}
Run Code Online (Sandbox Code Playgroud)