我是 json 新手。这是我的 json 对象。任何人请帮我为下面的 json 对象创建 C# 类
{
"JBS" : {
"name" : "Jobsite"
},
"LNK" : {
"name" : "Linked IN"
},
"MUK" : {
"name" : "Monster UK"
}
}
因为我需要 (JBS,jobsite ) 的信息,例如 n 个元素。
将类声明为:
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);
如果你想枚举结果,你应该尝试反序列化成字典。这是一个反序列化它然后列出它们的示例:
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; }
}
尝试使用json.net将 json 反序列化为动态对象。然后您应该能够访问这些属性。
也可以参考这个问题:Deserialize json object into dynamic object using Json.net