使用变量名数组反序列化 JSON

Bra*_*ton 4 c# json json.net json-deserialization

我正在获取从 REST Web 服务返回的用于调查响应的 JSON。它有一些名称值对的名称部分的数组。此外,名称将根据所问问题的类型而变化。我正在使用 JSON.net 并尝试将返回的值反序列化为某种类型的对象树,我可以遍历该对象树,但无法确定使用什么结构来填充它。

我在 LinqPad 中测试了以下代码段,并且字段始终为空。有什么方法可以轻松读取变量数据还是必须在代码中解析它?

void Main() {
    string json = @"{
      'result_ok':true,
      'total_count':'51',
      'data':[{
        'id':'1',
        'status':'Deleted',
        'datesubmitted':'2015-01-12 10:43:47',
        '[question(3)]':'Red',
        '[question(4)]':'Blue',
        '[question(18)]':12,
        '[variable(\'STANDARD_IP\')]':'127.0.0.1',
        '[variable(\'STANDARD_GEOCOUNTRY\')]':'United States'
      }]
    }";
    var responses = JsonConvert.DeserializeObject<RootObject>(json);
    responses.Dump();
}

public class RootObject {
    public bool result_ok { get; set; }
    public string total_count { get; set; }
    public List<Response> data { get; set; }
}

public class Response {
    public string id { get; set; }
    public string status { get; set; }
    public string datesubmitted { get; set; }
    public List<object> fields = new List<object>();
}
Run Code Online (Sandbox Code Playgroud)

Bri*_*ers 5

fieldsResponse类中的属性更改为 a Dictionary<string, object>,然后使用如下[JsonExtensionData]属性标记它:

public class Response
{
    public string id { get; set; }
    public string status { get; set; }
    public string datesubmitted { get; set; }
    [JsonExtensionData]
    public Dictionary<string, object> fields { get; set; }
}
Run Code Online (Sandbox Code Playgroud)

然后将所有具有奇怪属性名称的字段放入字典中,您可以在其中正常访问它们。不需要额外的代码。

这是一个演示:https : //dotnetfiddle.net/1rQUXT