我正在使用OpenCalais的API,它为我提供了一个包含一堆JSON对象的json字符串。问题是,根据我传入API的内容,JSON字符串的结构会发生变化,这意味着我无法对自己可以制作的自定义类强制执行deseralization。另一个问题是输出不是键值形式,而是复杂的对象结构。以下是输出的示例 -
{"doc":
{"info":
{"allowDistribution":"true",
"allowSearch":"true",
"calaisRequestID":"c1cdd79a-ed89-8431-138c-50e8a37100f9",
"externalID":"17cabs901",
"id":"http://id.opencalais.com/0RCcU306*HTR05*7HlUb5A",
"docId":"http://d.opencalais.com/dochash-1/6188237f-a2a5-3263-95b7-ea894ba98298",
"document":"Bill Gates worked at Microsoft from 2008 to 2011. He is also married to Melinda Gates.",
"docTitle":"",
"docDate":"2012-07-26 15:51:00.885",
"externalMetadata":"",
"submitter":"ABC"}
所以你可以看到这里有多个对象级别,没有键值结构。我需要的代码基本上是字典中的所有名称/值信息。然后我可以根据相关信息的键进行排序。如果我能以某种方式获取对象值的父级,那也很酷。所以例如我想要的输出是key:allowSearch,value:true,parent:info。我一直在尝试使用不同的反序列化方法,动态对象以及使用.Ancestor之类的函数进行简单解析,但我没有找到任何有用的东西。任何帮助将不胜感激。
答案 0 :(得分:3)
你看过JSON.NET了吗?它可以动态解析您可以迭代的JSON:
using Newtonsoft.Json.Linq;
JObject rootObject = JObject.Parse(jsonString);
您可以遍历子项,或搜索其他节点:
JToken info = rootObject.SelectToken("info");
答案 1 :(得分:1)
Json.NET支持Newtonsoft.Json.Linq
命名空间下的 LINQ to JSON 。
The example使用JObject
JObject o = JObject.Parse(@"{'CPU': 'Intel','Drives': ['DVD read/writer','500 gigabyte hard drive']}");
string cpu = (string)o["CPU"];
// Intel
string firstDrive = (string)o["Drives"][0];
// DVD read/writer
IList<string> allDrives = o["Drives"].Select(t => (string)t).ToList();
// DVD read/writer
// 500 gigabyte hard drive
答案 2 :(得分:0)
您可以使用基本上返回Dictionary<string, object>
的{{3}}。
例如:
JavaScriptSerializer serializer = new JavaScriptSerializer();
Dictionary<string, object> myGraph = (Dictionary<string, object>)serializer.DeserializeObject(myJson);
要阅读myGraph
字典中的内容,您必须逐步完成每一步。
例如:
Dictionary<string, object> doc = (Dictionary<string, object>)myGraph["doc"];
Dictionary<string, object> info = (Dictionary<string, object>)doc["info"];
string externalID = (string)info["externalID"];
我确信你可以对它进行一般化,但我认为这应该适用于你发布的json。