根据字符索引确定 JSONPath



C#中是否有可能从char索引位置获取JSONPath?即想象将文本光标放在JSON字符串中,并希望从该位置了解JSONPath。

JObject o = JObject.Parse(@"{""items"":[{""item1"":""Something1""},{""item2"":""Something2""},{""item3"":""Something3""},{""item4"":""Something4""}]}}");
int charindex = 26;
string jsonpath = o.GetToken(charindex); // imaginary method call
jsonpath == "$.items[?(@.Item1 == 'Something1')]";

我已经搜索了一个库或代码片段来帮助没有运气。最好的方法是什么?正则表达式合适吗?

我认为NewtonSoft的JsonTextReader可以使用PathLineNumberLinePosition属性为您提供所需的内容。

例如,此代码:

var s = @"
    {
        ""obj"": {
            ""foo"": ""bar""
        },
        ""arr"": [
            1,
            2,
            3
        ]
    }
";
using(var sr = new System.IO.StringReader(s))
{
    var r = new Newtonsoft.Json.JsonTextReader(sr);
    while (r.Read())
        Console.WriteLine(r.LineNumber + ":" + r.LinePosition + " : " + r.Path);
}

将给出以下输出:

2:5 : 
3:14 : obj
3:16 : obj
4:18 : obj.foo
4:24 : obj.foo
5:9 : obj
6:14 : arr
6:16 : arr
7:13 : arr[0]
8:13 : arr[1]
9:13 : arr[2]
10:9 : arr
11:5 : 

但是,如果您真的只想使用 char 索引,您可能希望将 json 字符串中的所有 newLines 和 carriageReturns 替换为空格,这样所有内容都在一行上......

现在获取字符串中特定位置的路径很容易:

var charIndex = 48;
var s = @"
    {
        ""obj"": {
            ""foo"": ""bar""
        },
        ""arr"": [
            1,
            2,
            3
        ]
    }
";
s = s.Replace("n", " ").Replace("r", " ");
var path = "";
using(var sr = new System.IO.StringReader(s))
{
    var r = new Newtonsoft.Json.JsonTextReader(sr);
    while (r.Read() && r.LinePosition <= charIndex )
        path = r.Path;
}
Console.WriteLine(path); // obj.foo

相关内容

  • 没有找到相关文章

最新更新