C#在JSON中搜索而不进行反序列化

C#在JSON中搜索而不进行反序列化,c#,json,json.net,C#,Json,Json.net,我的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"

我的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可以做到这一点吗?

如果您不想一次将整个文档读入内存,可以使用。它不会自动为你做很多事情,它只是向前的。用法示例:

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"]);
        }
    }
}

我建议你在“低端”设备上试用。json的反序列化相当轻量级。他喜欢这个json。那些{}集需要名称或其他东西。当然,您可以直接使用。请参阅或。@puropoix jsonlint.com正在抱怨,因为没有引用属性名称。