c# - 在不知道索引的情况下在 C# 中解析 json

标签 c# .net json mono json.net

我想用 JSON.NET 在 C# 中解析这段 JSON,但我不知道如何去做。

JSON:

{
   "success":true,
   "rgInventory":{
       "967633758":{
          "id":"967633758",
          "classid":"23973033",
          "instanceid":"11040671",
          "amount":"1",
          "pos":1
       },
      "302756826":{
          "id":"302756826",
          "classid":"15",
          "instanceid":"11041143",
          "amount":"1",
          "pos":2
      },...
   }
}

完整的 Json:http://steamcommunity.com/id/jessecar/inventory/json/440/2/?trading=1

我需要获取每个“rgInventory”子项的元素,但我无法为其创建一个类,因为项目名称总是在变化。

我尝试使用这段代码,但总是出现异常。

dynamic jsObject = JsonConvert.DeserializeObject(jsonString);

Console.WriteLine("Status: "+jsObject["success"]); //This works fine

foreach(var i in jsObject["rgInventory"]){
    Console.WriteLine("Item ID: "+i["id"]); //This gives an exception
}

异常(exception):

Unhandled Exception: System.InvalidOperationException: Cannot access child value on Newtonsoft.Json.Linq.JProperty.

最佳答案

这应该有效。

var jObj = (JObject)JsonConvert.DeserializeObject(json);
foreach(var child in jObj["rgInventory"].Children())
{
    Console.WriteLine("Item ID: {0}", child.First()["id"]);
}

此外,使用 dynamic 关键字可以使您的代码更具可读性:

dynamic jObj = JsonConvert.DeserializeObject(json);
Console.WriteLine("Status: " + jObj.success); 
foreach(var child in jObj.rgInventory.Children())
{
    Console.WriteLine("Item ID: {0}", child.First.id);
}

关于c# - 在不知道索引的情况下在 C# 中解析 json,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11446989/

相关文章:

c# - 从带参数的方法调用带参数的方法

c# - 无法使用 ABCPDF 将字节数组(从 .docx 文件创建)读入 Doc 对象

java - 如何在值类型和键值对数量未知的情况下 HashMap JSON 的键值对

c# - 编码结构数组指针的方法

c# - 来自普通 SQL 的 Oracle sys_refcursor

c# - 是否有一种通用方法可以通过主键获取 Linq2SQL 实体?

c# - 绑定(bind)行选择

c# - ASP Repeater获取多个选定行的值

javascript - 具有动态 HTML 模板的 AngularJS 递归指令

java - 从 Java 代码将 JSON 文件批量上传/导入到 Azure Cosmos DB