我的Windows 10 Universal App中有一个JSON文本文件相当大(> 40MB).这是一个像这样的对象数组:
[{"prop1": "X", "prop2": "hjk", "prop3": "abc"}, {"prop1": "X", "prop2": "lmn", "prop3": "def"}, {"prop1": "Y", "prop2": "opq", "prop3": "abc"}, {"prop1": "Y", "prop2": "rst", "prop3": "def"}]
我希望能够只检索几行,例如,在任何属性中包含字符串"abc"的每个对象以及prop1上的"Y".
预期结果:
[{prop1: "Y", prop2: "opq", prop3: "abc"}]
我害怕将其全部反序列化,因为对于像手机这样的低端设备而言可能太过分了.可以使用JSON.NET完成吗?
如果要避免一次将整个文档读入内存,可以使用JsonTextReader
该类.它不会自动为你做太多,而且它只是前瞻性的.用法示例:
using (var fs = File.OpenRead(path)) using (var textReader = new StreamReader(fs)) using (var reader = new JsonTextReader(textReader)) { while (reader.Read()) { if (reader.TokenType == JsonToken.StartObject) { var obj = JObject.Load(reader); Debug.WriteLine("{0} - {1}", obj["id"], obj["name"]); } } }