繁体   English   中英

如何解析此JSON结构?

[英]How do I parse this JSON structure?

如何解析此JSON? 我不知道如何定义这种结构:

[
    [{
        "timestamp": 1324374926
    }],
    [{
        "id": "9",
        "neme": "qqq"
    }, {
        "id": "19",
        "neme": "qqq"

    }, {
        "id": "29",
        "neme": "qqq"
    }]
]

JSON解析代码:

DataContractJsonSerializer serializer = new DataContractJsonSerializer(typeof(Categor[]));
 Categor[] result = (Categor[])serializer.ReadObject(responseStream);

通过定义数据合同...

编译器返回:

System.InvalidCastException:的InvalidCastException
System.Runtime.Serialization.Json.DataContractJsonSerializer.ConvertObjectToDataContract(DataContract
合同,对象值,XmlObjectSerializerReadContextComplexJson
上下文)
System.Runtime.Serialization.Json.ObjectToDataContractConverter.ConvertICollectionToCollectionDataContract(DataContractJsonSerializer
序列化程序,CollectionDataContract合同,对象反序列化值,
XmlObjectSerializerReadContextComplexJson上下文),网址为
System.Runtime.Serialization.Json.DataContractJsonSerializer.ConvertObjectToDataContract(DataContract
合同,对象值,XmlObjectSerializerReadContextComplexJson
上下文)在System.Runtime.Serializati

如何解析此JSON?

重要的是,对于普通的JSON,我正在创建fe:

DataContractJsonSerializer serializer = new DataContractJsonSerializer(typeof(Categor[]));
 Categor[] result = (Categor[])serializer.ReadObject(responseStream);
[

{
    "category": "A",
    "subcategories": [
        {
            "id": "QW",
            "name": "A",
            "ranking": 100,
            "isVisible": true
        },
        {
            "id": "QWN0d",
            "name": "Pol",
            "ranking": 101,
            "isVisible": false
        },

...

数据模型为:

   [DataContract]
    public class Articlesubcat
    {
        [DataMember(Name = "id")]
        public string id { get; set; }
        [DataMember(Name = "name")]
        public string name { get; set; }
        [DataMember(Name = "ranking")]
        public string ranking { get; set; }
        [DataMember(Name = "isVisible")]
        public string isVisible { get; set; }

    }

    [DataContract]
    public class Categor
    {
           [DataMember(Name = "category")]
        public string category { get; set; }
            [DataMember(Name = "subcategories")]
        public List<Articlesubcat> subcat { get; set; }
    }

但是显然在这个JSON中我有:

[
[
 {
    "timestamp": 1324374926
 }
],
[
  {
    "id": "9",
    "neme": "qqq"
  }, 
  {
    "id": "19",
    "neme": "qqq"

   },
   {
    "id": "29",
    "neme": "qqq"
   }
 ]
]

而且正如我所见,我不知道如何为这2个对象(数组对象)进行模型预修,或者我什至不知道此结构的名称是什么。

即使您没有向我们显示Categor的声明, Categor[]也不是JSON数据的正确根类型。

JSON数据是某物阵列阵列 因此,您的根数据类型必须类似于Categor[][]

更新:

感谢您发布Categor的声明。 现在很明显,您的JSON示例不是Categor实例的数组。 相反,它是两个元素的数组。 第一个是一些未知对象类型的数组。 它包含一个名为timestamp的属性。 因此它不能是Categor实例。 第二个元素是Categor实例的数组(可能是您期望的部分)。

幸运的是,您可以使用根类型Categor[][]解析JSON,然后仅使用最外层数组的第二个元素。 如果这不起作用,则由于DataContractJsonSerializer对于混合类型数组有一些限制,您可能必须切换到其他JSON库。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM