gpt4 book ai didi

php - 制作一个 JSONpath 表达式以便它只检索一个特定的值?

转载 作者:可可西里 更新时间:2023-11-01 00:04:13 25 4
gpt4 key购买 nike

我有一些 JSON,以下是其中的一个小样本:

{
"results": {
"div": [
{
"class": "sylEntry",
"div": [
{
"class": "sT",
"id": "sOT",
"p": "Mon 11/17, Computer work time"
},
{
"class": "des",
"id": "dOne",
"p": "All classes Siebel 0218"
}
],
"id": "sylOne"
}
]
}
}

我只想检索类 "sT" 的 div 元素的 "p" 内容。我想使用一个循环并做这样的事情:

var arrayOfResults = $.results..div.p 

不起作用,因为我只想检索类 "sT" 的 div 元素的 p 值。

那么我该如何构造我的 JSONpath,以便它能够检索包含在 div 类“sT”中的 p 元素数组。

谢谢!!

最佳答案

概念

JSONPath 显然有一个过滤语法,允许您将任意 Javascript 插入到表达式中以进行匹配或过滤。它还使用 @ 作为当前节点的快捷方式。 Their example结合这两件事看起来像这样:

$..book[?(@.price<10)] // filter all books cheapier than 10

所以这可能就是您想在这里使用的内容。

解决方案

为了测试我想到的查询,我修改了 jsonpath-test-js.html文件在 JSONPath's repo测试你的数据。您可以将我的示例复制粘贴到 HTML 文件中,然后将其加载到浏览器中。

他们的测试套件有一个对象数组,其中包含名为 op 的字段。 o 包含要操作的原始数据,而 p 包含要应用于 o 的 JSONPath 表达式数组。它遍历所有这些对并将所有 p 应用于它们各自的 o,打印出结果。不像简单的 REPL 那样方便,但它可以。

这是我想出的:

<html>
<head>
<title> JSONPath - Tests (js)</title>
<script type="text/javascript" src="http://www.json.org/json.js"></script>
<script type="text/javascript"
src="http://jsonpath.googlecode.com/svn/trunk/src/js/jsonpath.js">
</script>
</head>
<body>
<pre>
<script type="text/javascript">
var out = "", tests =
[ { "o": { "results" : { "div" : [ { "clazz": "sylEntry",
"id": "sylOne", "div": [ { "clazz": "sT", "id": "sOT",
"p": "Mon 11/17, Computer work time" }, { "clazz": "des",
"id": "dOne", "p": "All classes Siebel 0218" } ] } ] } },
"p": ["$.results..div[?(@.clazz=='sT')].p", // my suggestion expression
"$.results..div[*].p"]}, // your question's expression
];

function evaluate($, p) {
var res = eval(p);
return res != null ? res.toJSONString() : null;
}

for (var i=0; i<tests.length; i++) {
var pathes;
for (var j=0; j<tests[i].p.length; j++) {
pre = ">";
if (pathes = jsonPath(tests[i].o, tests[i].p[j], {resultType: "PATH"}))
for (var k=0; k<pathes.length; k++) {
out += pre + " " + pathes[k] +
" = " + evaluate(tests[i].o, pathes[k]) + "\n";
pre = " ";
}
}
out += "<hr/>";
}
document.write(out);
</script>
</pre>
</body>
</html>

请注意,这将首先打印我的查询表达式的结果,然后打印您的结果,因此我们可以比较它们产生的结果。

这是它产生的输出:

> $['results']['div'][0]['div'][0]['p'] = "Mon 11/17, Computer work time"
> $['results']['div'][0]['div'][0]['p'] = "Mon 11/17, Computer work time"
$['results']['div'][0]['div'][4]['p'] = "All classes Siebel 0218"

因此过滤器表达式中的正确运算符是 ==,这意味着您的正确表达式是:

$.results..div[?(@.class=='sT')].p

但是,我发现了一个不幸的问题(至少在 JSONPath 的 Javascript 实现中):在上述查询中使用单词“类”会导致:

SyntaxError: jsonPath: Parse error: _v.class=='sT'

我唯一的猜测是在某处调用了一个 eval 来实际评估 JSONPath 表达式。 class 是 Javascript 中的保留字,因此会导致问题。让我们尝试使用 @.class 的替代语法:

$.results..div[?(@.['class']=='sT')].p

结果:

> $['results']['div'][0]['div'][0]['p'] = "Mon 11/17, Computer work time"
> $['results']['div'][0]['div'][0]['p'] = "Mon 11/17, Computer work time"
$['results']['div'][0]['div'][5]['p'] = "All classes Siebel 0218"

所以使用上面的表达式,你应该可以开始了!过滤器功能看起来很强大,因此可能值得探索它的功能!

关于php - 制作一个 JSONpath 表达式以便它只检索一个特定的值?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2916797/

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