我的Windows10Universal应用程序中有一个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 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"]);
        }
    }
}

10-04 14:33