首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >无法将当前JSON数组(例如[1,2,3])反序列化为'System.Collections.Generic.Dictionary‘类型

无法将当前JSON数组(例如[1,2,3])反序列化为'System.Collections.Generic.Dictionary‘类型
EN

Stack Overflow用户
提问于 2018-10-16 12:18:06
回答 2查看 2.4K关注 0票数 4

我有以下由第三方交付的JSON格式:

代码语言:javascript
运行
复制
{
"data": {
    "objects": {
        "0ea73fa9333a7cbeb2d8c69a14b9970f": {
            "Id": "0ea73fa9333a7cbeb2d8c69a14b9970f",
            "Name": "test"
        },
        "38b1390ff6bc8a9837105d181000bcc8": {
            "Id": "38b1390ff6bc8a9837105d181000bcc8",
            "Name": "test"
        }
    }
}}

我使用这个模型进行反序列化:

代码语言:javascript
运行
复制
public class ObjectTypes
{
    public ObjectTypeList data { get; set; }

    public class ObjectTypeList
    {
        public Dictionary<string, Object> objects { get; set; }
    }

    public class Object
    {
        public string Id { get; set; }
        public string Name { get; set; }
    }
}

这很好,但是有时JSON是空的,如下所示:

代码语言:javascript
运行
复制
{
"data": {
    "objects": []
}
}

这导致了这一例外:

无法将当前的JSON数组(例如,1,2,3)反序列化为'System.Collections.Generic.Dictionary`2System.String,Models.ObjectTypes+Object‘,因为该类型需要一个JSON对象(例如{“名称”:“值”})才能正确反序列化。要修复此错误,要么将JSON更改为JSON对象(例如,{"name":"value"}),要么将反序列化类型更改为数组,或者将实现集合接口(例如ICollection、IList)的类型改为可以从JSON数组反序列化的列表。还可以将JsonArrayAttribute添加到该类型中,以强制它从JSON数组中反序列化。路径'data.objects',第1行,位置20。

对于如何解决这个问题,有什么建议吗?

EN

回答 2

Stack Overflow用户

发布于 2018-10-16 12:42:05

您应该对ObjectTypes类型进行反序列化。

代码语言:javascript
运行
复制
        public partial class ObjectTypes
        {
            [JsonProperty("data")]
            public Data Data { get; set; }
        }

        public partial class Data
        {
            [JsonProperty("objects")]
            public Dictionary<string, Object> Objects { get; set; }
        }

        public partial class Object
        {
            [JsonProperty("Id")]
            public string Id { get; set; }

            [JsonProperty("Name")]
            public string Name { get; set; }
        }
票数 0
EN

Stack Overflow用户

发布于 2018-10-16 13:30:51

正如我在评论中提到的,json结构在两个字符串中都不匹配。objects可以是对象(字典),也可以是数组

我已经创建了一个小的解析器类,它将解析json并检查objects对象(字典)还是数组。在第一种情况下,它将返回一个空的ObjectTypes对象,但在第二种情况下,它将反序列化json字符串为ObjectTypes对象。

代码语言:javascript
运行
复制
public class ObjectTypesParser
{
    public ObjectTypes Parse(string json)
    {
        JToken token = JToken.Parse(json);
        var objectsToken = token.First.First.First.FirstOrDefault();

        if (objectsToken is JArray)
        {
            /*
             Special case - json with an empty array:

            {
                ""data"": {
                    ""objects"": []
                }
            }

            */
            return new ObjectTypes();
        }

        // json containing a dictionary:
        ObjectTypes data = JsonConvert.DeserializeObject<ObjectTypes>(json);

        return data;
    }
}

C#类:

代码语言:javascript
运行
复制
public class ObjectTypes
{
    [JsonProperty("data")]
    public ObjectTypeList Data { get; set; }

    public ObjectTypes()
    {
        Data = new ObjectTypeList();
    }
}

public class ObjectTypeList
{
    [JsonProperty("objects")]
    public Dictionary<string, ObjectData> Objects { get; set; }

    public ObjectTypeList()
    {
        Objects = new Dictionary<string, ObjectData>();
    }
}

public class ObjectData
{
    [JsonProperty("Id")]
    public string Id { get; set; }

    [JsonProperty("Name")]
    public string Name { get; set; }
}

使用代码:

代码语言:javascript
运行
复制
string json1 = @"{
""data"": {
    ""objects"": {
        ""0ea73fa9333a7cbeb2d8c69a14b9970f"": {
            ""Id"": ""0ea73fa9333a7cbeb2d8c69a14b9970f"",
            ""Name"": ""test""
        },
        ""38b1390ff6bc8a9837105d181000bcc8"": {
            ""Id"": ""38b1390ff6bc8a9837105d181000bcc8"",
            ""Name"": ""test""
        }
    }
}}";

string json2 = @"{
""data"": {
    ""objects"": []
}
}";


var parser = new ObjectTypesParser();
ObjectTypes data1 = parser.Parse(json1);
ObjectTypes data2 = parser.Parse(json2);
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/52835302

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档