EDIT:我想好了如何获得每个键,现在问题是在每个集合中循环。解决方案在底部
我正在尝试解析具有以下格式的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
文档中还有许多其他示例。