首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >将没有根对象的json反序列化为c#/vb.net类

将没有根对象的json反序列化为c#/vb.net类
EN

Stack Overflow用户
提问于 2015-05-16 18:51:59
回答 2查看 4.6K关注 0票数 3

我想构建一个使用JSON服务的vb.net应用程序。下面是调用此服务时收到的数据示例:

代码语言:javascript
复制
[
{"id":17552,"title":"Avatar","alternative_title":null,"year":2009},
{"id":31586,"title":"Avatar","alternative_title":"Cyber Wars","year":2004},
{"id":81644,"title":"Aliens vs. Avatars","alternative_title":null,"year":2011}
]

我尝试过一些像json2csharp这样的工具来从这个例子中生成一个类,但是这些工具生成的类如下所示:

代码语言:javascript
复制
public class RootObject
{
public int id { get; set; }
public string title { get; set; }
public string alternative_title { get; set; }
public int year { get; set; }
}

该类忽略了从服务返回列表的事实。我假设这是由于json输出没有从根级对象开始的事实。

对于这个json输出,我的c#/vb.net类是什么样子的,或者应该“手动”解析它?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2015-05-16 20:20:18

您可以使用Json.Net,并反序列化数组:

代码语言:javascript
复制
var result = JsonConvert.DeserializeObject<RootObject[]>(json_string);
票数 4
EN

Stack Overflow用户

发布于 2015-05-16 20:16:16

我不知道你到底有什么问题。使用Newtonsoft Json.NET,JsonConvert.DeserializeObject<IEnumerable<RootObject>>(input),即:

代码语言:javascript
复制
var s = "[{\"id\":17552,\"title\":\"Avatar\",\"alternative_title\":null,\"year\":2009}," +
         "{\"id\":31586,\"title\":\"Avatar\",\"alternative_title\":\"Cyber Wars\",\"year\":2004}," +
         "{\"id\":81644,\"title\":\"Aliens vs. Avatars\",\"alternative_title\":null,\"year\":2011}]";

var result = JsonConvert.DeserializeObject<IEnumerable<RootObject>>(s);
foreach (var r in result)
    Console.WriteLine("{0} - {1}, {2} ({3})", r.id, r.title, r.alternative_title, r.year);

为我生成以下输出:

代码语言:javascript
复制
17552 - Avatar,  (2009)
31586 - Avatar, Cyber Wars (2004)
81644 - Aliens vs. Avatars,  (2011)
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/30279528

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档