我正在使用Newtonsoft json序列化程序将json字符串转换为对象。我有json结构如下 -
{
"EmployeeRecords": {
"12": {
"title": "Mr",
"Name": "John"
},
"35":{
"title": "Mr",
"Name": "Json"
}
}
}
我希望将这个Json加入到下面的类中 -
public class Employee
{
public string EmployeeNumber { get; set; }
public string title { get; set; }
public string Name { get; set; }
}
public class EmployeeRecords
{
public List<Employee> Employees { get; set; }
}
这里雇员人数是12和35。
请指导我如何编写自定义serilizer,它将从父节点读取Employee编号并将其包含在子节点的EmployeeNumber属性中。
答案 0 :(得分:1)
您可以反序列化为字典,然后循环分配EmployeeNumbers。
public class DataModel
{
public Dictionary<string, Employee> EmployeeRecords { get; set; }
}
反序列化后确定数字:
var records = JsonConvert.DeserializeObject<DataModel>(json);
foreach (var item in records.EmployeeRecords)
{
item.Value.EmployeeNumber = item.Key;
}
答案 1 :(得分:0)
您可以使用LINQ to JSON(JObject
和朋友)轻松完成此操作。这是一个简短而完整的例子:
using System;
using System.Collections.Generic;
using Newtonsoft.Json.Linq;
public class Employee
{
public string EmployeeNumber { get; set; }
public string title { get; set; }
public string Name { get; set; }
public JProperty ToJProperty()
{
return new JProperty(EmployeeNumber,
new JObject {
{ "title", title },
{ "Name", Name }
});
}
}
public class EmployeeRecords
{
public List<Employee> Employees { get; set; }
public JObject ToJObject()
{
var obj = new JObject();
foreach (var employee in Employees)
{
obj.Add(employee.ToJProperty());
}
return new JObject {
new JProperty("EmployeeRecords", obj)
};
}
}
class Test
{
static void Main()
{
var records = new EmployeeRecords {
Employees = new List<Employee> {
new Employee {
EmployeeNumber = "12",
title = "Mr",
Name = "John"
},
new Employee {
EmployeeNumber = "35",
title = "Mr",
Name = "Json"
},
}
};
Console.WriteLine(records.ToJObject());
}
}
它可能不是最简单的代码(如果你很乐意改变你的结构,Ufuk的方法很棒),但它显示了可自定义的一切。