[英]Deserializing JSON with numbers as keys
编辑:我想出了如何获取每个键,现在问题是遍历每个集合。 解决方案在底部!
我正在尝试解析具有以下格式的 JSON 有效负载:
{
"version": "1.1",
"0": {
"artist": "Artist 1",
"title": "Title 1"
},
"1": {
"artist": "Artist 2",
"title": "Title 2"
},
...
"29": {
"artist": "Artist 30",
"title": "Title 30"
}
}
我不需要version
密钥,所以我在编写类代码时忽略了它。 这是我到目前为止:
public class Song
{
public string artist { get; set; }
public string title { get; set; }
}
我已经检查了 StackOverflow,我看到人们使用Dictionary<int, string>
解决类似的问题,但看起来人们并没有在根中拥有每个 JSON 对象。 我正在使用 JSON.net 来解析所有内容。
在 PHP 中,我可以轻松地使用json_decode()
并遍历数组并提取我需要的所有信息,但我被 C# 难住了。
编辑:解决方案从下面开始。
我查看了 JSON.net 文档,他们使用了字典,所以我尝试使用嵌套字典,它似乎有效!
Dictionary<int, Dictionary<string, string>> song = JsonConvert.DeserializeObject<Dictionary<int, Dictionary<string, string>>>(json);
我可以通过以下方式访问artist
和title
属性:
song[0]["artist"]
song[0]["title"]
分别。
这消除了对预构建类的需要。 现在我在遍历每组数据集时遇到问题(例如,歌曲 [1]、歌曲 [2]、歌曲 [3]、...、歌曲 [n] 的艺术家和标题信息)。
如果您尝试使用上述 JSON 反序列化为Dictionary<int, Dictionary<string, string>>
您将遇到version
键问题,因为它不适合词典的数据格式( version
不是int
,而1.1
不是Dictionary<string, string>
)。 我知道你说你“暂时忽略它”,但这意味着它将来会在那里,所以你需要处理它。
如果您不想拥有预定义的类,那么最好使用 Json.Net 的LINQ-to-JSON API来处理数据。 以下是使用此方法获取所需数据的方法:
class Program
{
static void Main(string[] args)
{
string json = @"
{
""version"": ""1.1"",
""0"": {
""artist"": ""Artist 1"",
""title"": ""Title 1""
},
""1"": {
""artist"": ""Artist 2"",
""title"": ""Title 2""
},
""29"": {
""artist"": ""Artist 30"",
""title"": ""Title 30""
}
}";
JObject songs = JObject.Parse(json);
foreach (JProperty song in songs.Properties())
{
if (song.Name == "version") continue; // skip "version" property
Console.WriteLine("Song " + song.Name + " artist: " + song.Value["artist"]);
Console.WriteLine("Song " + song.Name + " title: " + song.Value["title"]);
}
}
}
输出:
Song 0 artist: Artist 1
Song 0 title: Title 1
Song 1 artist: Artist 2
Song 1 title: Title 2
Song 29 artist: Artist 30
Song 29 title: Title 30
文档中还有许多其他示例。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.