如何解析 json 数组 json.net

How to parse a json array json.net

我知道这听起来很基础,但围绕这个问题的所有答案都是愚蠢的大而笨重的代码,不允许我需要的功能。我需要解析这个 json 数组。

[
   {
      "label":"Cow (1)",
      "value":3309
   },
   {
      "label":"Cow (1)",
      "value":14998
   },
   {
      "label":"Cow (4)",
      "value":20969
   },
   {
      "label":"Cow (4)",
      "value":20970
   },
   {
      "label":"Cow (4)",
      "value":20971
   },
   {
      "label":"Cowardly Bandit",
      "value":1886
   },
   {
      "label":"Cow calf (1)",
      "value":2310
   },
   {
      "label":"Coward in armour (82)",
      "value":5097
   },
   {
      "label":"Coward with bow (105)",
      "value":6049
   },
   {
      "label":"Cow calf (1)",
      "value":20979
   },
   {
      "label":"Undead cow (4)",
      "value":1691
   },
   {
      "label":"Plague cow",
      "value":1998
   },
   {
      "label":"Plague cow",
      "value":1999
   },
   {
      "label":"Unicow (57)",
      "value":5603
   },
   {
      "label":"Zombie cow (1)",
      "value":18597
   },
   {
      "label":"Zombie cow (1)",
      "value":20928
   },
   {
      "label":"Super Cow (5)",
      "value":21497
   },
   {
      "label":"Dairy cow",
      "value":22418
   },
   {
      "label":"Armoured cow thing (62)",
      "value":5986
   },
   {
      "label":"Armoured cow thing (62)",
      "value":6048
   }
]

当我尝试访问数组内的数据点时,它 returns 为空,代码:

Stream stream = client.OpenRead("http://services.runescape.com/m=itemdb_rs/bestiary/beastSearch.json?term=" + Input);
StreamReader reader = new StreamReader(stream);
jObject = JObject.Parse(reader.ReadToEnd());
stream.Close();
//put items into list view
// i is the number where the json object is in the array 
var lvi = new ListViewItem(new string[] { (string)jObject[i]["label"], (string)jObject[i]["value"] }); 

我不想用类

试试我对 的回答:

public IEnumerable<MeItem> DeserializeListFromJson(string jsonArray)
{
    return JsonConverter.DeserializeObject<List<JObject>>(jsonArray).Select( obj => DeserializeFromJson(obj) );
}

public MeItem DeserializeFromJson(string jsonString)
{
    return JsonConvert.DeserializeObject<MeItem>(jsonString);
}

你可以在我对

的回答中找到必要的详细信息

编辑:

如果你不想使用 类 那么你可以将 DeserializeFromJson() 方法修改成这样:

public KeyValuePair<string, string> DeserializeFromJson(JObject obj)
{
    return new KeyValuePair<string, string>(obj.SelectToken("label").Value<string>(), obj.SelectToken("value").Value<string>());
}

需要将DeserializeListFromJson()方法修改为:

public IEnumerable<KeyValuePair<string,string>> DeserializeListFromJson(string jsonArray)
{
    return JsonConverter.DeserializeObject<List<JObject>>(jsonArray).Select( obj => DeserializeFromJson(obj) );
}

在您的案例中的用法:

Stream stream = client.OpenRead("http://services.runescape.com/m=itemdb_rs/bestiary/beastSearch.json?term=" + Input);
ListViewItem item = null;
using (StreamReader reader = new StreamReader(stream))
{
    KeyValuePair<string, string> selected = DeserializeListFromJson(reader.ReadToEnd()).ElementAt(i);
    item = new ListViewItem(new string[] { selected.Key, selected.Value });
}

不想使用 类 很奇怪,但并非不可能。

var json = reader.ReadToEnd();
var objects = JsonConvert.DeserializeObject<dynamic[]>(json);
var lvi = new ListViewItem(new string[] { (string)objects[i].label, (string)objects[i].value }); 

在您的代码中发现错误。相反:

JObject.Parse(reader.ReadToEnd());

写入(JObject -> JArray):

string text = reader.ReadToEnd();
var jObject = JArray.Parse(text);

另外,当写两行操作时,你会看到错误的地方:从流中读取或序列化。