在
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
可以使用Path
,LineNumber
和LinePosition
属性为您提供所需的内容。
例如,此代码:
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