将 JSON 解析为对象



我正在使用盒子api,并尝试将json对象解析为类。
这是 json:

{
  "type":"folder",
  "id":"0",
  "sequence_id":null,
  "etag":null,
  "name":"All Files",
  "created_at":null,
  "modified_at":null,
  "description":"",
  "size":9049537,
  "path_collection":
  {
    "total_count":0,"entries":[]
  },
  "created_by":
  {
    "type":"user","id":"","name":"","login":""
  },
  "modified_by":
  {
    "type":"user",
    "id":"111",
    "name":"a a",
    "login":"a@gmail.com"
  },
  "trashed_at":null,
  "purged_at":null,
  "content_created_at":null,
  "content_modified_at":null,
  "owned_by":
  {
    "type":"user",
    "id":"111",
    "name":"a a",   
    "login":"a@gmail.com"   
  },    
  "shared_link":null,
  "folder_upload_email":null,
  "parent":null,
  "item_status":"active",
  "item_collection":
  {
    "total_count":4,
    "entries":
    [
      {
        "type":"file",
        "id":"22887167395",
        "sequence_id":"0",
        "etag":"0",
        "sha1":"883c99863eefc0f46b3d34915cc4d97a6008fabf",
        "name":"13.ppt"
      },
      {
        "type":"file",
        "id":"22887169687",
        "sequence_id":"0",
        "etag":"0",
        "sha1":"a345fd68b1c90a3678a3e746e0e5343693d8a022",
        "name":"6.docx"
      }
    ],
    "offset":0,
    "limit":100,
    "order":
    [
      {
        "by":"type",
        "direction":"ASC"
      },
      {
        "by":"name",
        "direction":"ASC"
      }
    ]
  }
}

基本上,这是包含两个文件的
根文件夹(在这种情况下):13.ppt
6.docx
我创建了一个类:

[JsonObject(MemberSerialization.OptIn)]
public class BoxFile
{
    [JsonProperty(PropertyName = "type")]
    public string Type { get; internal set; }
    [JsonProperty(PropertyName = "id")]
    public string Id { get; internal set; }
    [JsonProperty(PropertyName = "sequence_id")]
    public string SequenceId { get; internal set; }
    [JsonProperty(PropertyName = "etag")]
    public string Etag { get; internal set; }
    [JsonProperty(PropertyName = "name")]
    public string Name { get; internal set; }
    [JsonProperty(PropertyName = "created_at")]
    public string CreatedAt { get; internal set; }
    [JsonProperty(PropertyName = "modified_at")]
    public string ModifiedAt { get; internal set; }
    [JsonProperty(PropertyName = "description")]
    public string Description { get; internal set; }
    [JsonProperty(PropertyName = "size")]
    public long Size { get; internal set; }
    [JsonProperty(PropertyName = "item_collection")]
    public IEnumerable<BoxFile> ItemCollection { get; internal set; }
}  

但是"item_collection"部分不起作用......它给了我一个错误。

如何获取"item_collection"中的子文件列表?

我通过以下方式使用它:

    private T ParseJson<T>(string json) where T : class, new()
    {
            JObject jobject = JObject.Parse(json);
            return JsonConvert.DeserializeObject<T>(jobject.ToString());
    }  

和:

BoxFile parsed = ParseJson<BoxFile>(json);

您收到错误,因为您的类结构与您的 JSON 不匹配。 具体来说,在 JSON 中,item_collection 属性是一个对象,而不是一个列表。 该JSON对象有两个属性,total_countentries,后者包含实际的文件列表。 要处理这个问题,你需要定义另一个类:

public class ItemCollection
{
    [JsonProperty(PropertyName = "entries")]
    public IEnumerable<BoxFile> Entries { get; internal set; }
}

,然后将 BoxFile 类中的 ItemCollection 属性更改为使用此新类:

    [JsonProperty(PropertyName = "item_collection")]
    public ItemCollection ItemCollection { get; internal set; }

然后,您可以访问如下文件列表:

BoxFile parsed = ParseJson<BoxFile>(json);
foreach (BoxFile file in parsed.ItemCollection.Entries)
{
    Console.WriteLine(file.Name);
}

这是一个工作演示:https://dotnetfiddle.net/DB9Coc

顺便说一句,您可以将ParseJson方法简化为一行。 没有必要将JSON解析为JObject,将其重新转换为JSON,然后再次解析。

private T ParseJson<T>(string json) where T : class, new()
{
    return JsonConvert.DeserializeObject<T>(json);
}

相关内容

  • 没有找到相关文章

最新更新