1

我是 json 新手。这是我的 json 对象。任何人请帮我为下面的 json 对象创建 C# 类

{
   "JBS" : {
      "name" : "Jobsite"
   },
   "LNK" : {
      "name" : "Linked IN"
   },
   "MUK" : {
      "name" : "Monster UK"
   }
}

因为我需要 (JBS,jobsite ) 的信息,例如 n 个元素。

4

3 回答 3

5

将类声明为:

public class Entity
{
    public string name{get; set;}
}

public class JsonData
{
    public Entity JBS{get;set;}
    public Entity LNK{get;set;}
    public Entity MUK{get;set;}
}

然后使用:

var json =
   @"{'JBS' : {'name' : 'Jobsite'},
   'LNK' : {'name' : 'Linked IN'},
   'MUK' : {'name' : 'Monster UK'}}";


JsonData jsonData = new System.Web.Script.Serialization.JavaScriptSerializer().Deserialize<JsonData>(json);

}

更新

我认为这个片段符合您的要求。

var json =
@"{ 'JBS' : {'name' : 'Jobsite'},
    'LNK' : {'name' : 'Linked IN'},
    'MUK' : {'name' : 'Monster UK'}}";


var jsonData = new System.Web.Script.Serialization.JavaScriptSerializer()
.Deserialize<Dictionary<string,Dictionary<string, string>>>(json)
.ToDictionary(d => d.Key, d => d.Value.First().Value);
于 2013-09-14T06:06:33.283 回答
2

如果你想枚举结果,你应该尝试反序列化成字典。这是一个反序列化它然后列出它们的示例:

var json = "{ \"JBS\" : { \"name\" : \"Jobsite\" }, \"LNK\" : { \"name\" : \"Linked IN\" }, \"MUK\" : { \"name\" : \"Monster UK\" } }";

var result = new System.Web.Script.Serialization.JavaScriptSerializer().Deserialize<Dictionary<string, JobSite>>(json);

var jobsites = new List<JobSite>(result.Count);

foreach (var pair in result)
{
    var jobsite = pair.Value;
    jobsite.Short = pair.Key;
    jobsites.Add(jobsite);
}

该示例使用如下所示的类:

public class JobSite
{
    public string Short { get; set; }
    public string Name { get; set; }
}
于 2013-09-14T06:51:16.580 回答
0

尝试使用json.net将 json 反序列化为动态对象。然后您应该能够访问这些属性。

也可以参考这个问题:Deserialize json object into dynamic object using Json.net

于 2013-09-14T05:50:28.903 回答