我的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"的每个对象。在任何财产和" Y"在prop1。
预期结果:
[{prop1: "Y", prop2: "opq", prop3: "abc"}]
我害怕将其全部反序列化,因为对于像手机这样的低端设备而言,这可能太过分了。可以使用JSON.NET吗?
答案 0 :(得分:6)
如果您想避免一次将整个文档读入内存,可以使用JsonTextReader
class。它不会自动为你做太多事情,而且它只是前瞻性的。用法示例:
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"]);
}
}
}