gpt4 book ai didi

C# 在不反序列化的情况下在 JSON 中搜索

转载 作者:太空狗 更新时间:2023-10-30 00:50:05 24 4
gpt4 key购买 nike

我的 Windows 10 通用应用程序中有一个相当大 (>40MB) 的 JSON 文本文件。它是这样的对象数组:

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

关于C# 在不反序列化的情况下在 JSON 中搜索,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34030918/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com