Filter expression with addition
Setup
Selector: $[?(@.key+50==100)]
[{"key": 60}, {"key": 50}, {"key": 10}, {"key": -50}, {"key+50": 100}]
Results
Other responses
Bash (JSONPath.sh)
[]
C (json-glib)
Not supported
Unable to compile selector `$[?(@.key+50==100)]': Invalid array index definition “?(@.key+50==100)]”
Clojure (json-path)
¹
[
{
"key": 60
},
{
"key": 50
},
{
"key": 10
},
{
"key": -50
},
{
"key+50": 100
}
]
Cpp (jsoncons)
[
{
"key": 50
}
]
Dart (json_path)
Not supported
FormatException: end of input expected at 1:2. Expression: $[?(@.key+50==100)]
Elixir (ExJsonPath)
Not supported
illegal characters "+"
Elixir (jaxon)
[]
Elixir (warpath)
¹
[
{
"key+50": 100
}
]
Not supported
invalid syntax (position=1, reason=unrecognized input, near=[?(@.key+50==100)])
Not supported
parsing error: $[?(@.key+50==100)] :1:10 - 1:11 unexpected "+" while scanning parentheses expected ")"
[
{
"key": 50
}
]
[
{
"key": 50
}
]
[]
[
{
"key": 50
}
]
[
{
"key+50": 100
}
]
Haskell (jsonpath)
Not supported
Invalid JSONPath: $[?(@.key+50==100)]
Error: 1:10:
|
1 | $[?(@.key+50==100)]
| ^
unexpected '+'
expecting "!=", "&&", "<=", "==", ">=", "||", '!', ')', '.', '<', '>', '[', or white space
JavaScript (Goessner)
²
[
{
"key": 50
}
]
JavaScript (brunerd)
[
{
"key": 50
}
]
JavaScript (jsonpath)
[
{
"key": 50
}
]
JavaScript (jsonpath-plus)
[
{
"key": 50
}
]
Java (com.github.jsurfer)
[
{
"key+50": 100
}
]
Java (com.jayway.jsonpath)
¹
³
[
{
"key+50": 100
}
]
Kotlin (com.nfeld.jsonpathkt)
¹
Not supported
Unexpected char, char=?, index=2
Objective-C (SMJJSONPath)
¹
³
[
{
"key+50": 100
}
]
PHP (galbar-jsonpath)
²
Not supported
Invalid JSONPath error: 'Error in JSONPath near '+50''
PHP (remorhaz-jsonpath)
Not supported
Error: 'Failed to build AST from JSONPath query: $[?(@.key+50==100)]'
PHP (softcreatr-jsonpath)
[
{
"key+50": 100
}
]
Python (jsonpath)
²
[
{
"key": 50
}
]
Python (jsonpath-ng)
Not supported
JsonPathLexerError('Error on line 1, col 2: Unexpected character: ? ')
Python (jsonpath-rw)
Not supported
JsonPathLexerError('Error on line 1, col 2: Unexpected character: ? ')
Python (jsonpath2)
Not supported
line 1:9 token recognition error at: '+'
ValueError("line 1:9 token recognition error at: '+'")
Raku (JSON-Path)
Not supported
Evaluation of embedded Perl 6 code not allowed (construct with :allow-eval)
Rust (jsonpath)
Not supported
parsing error
Rust (jsonpath_lib)
[
{
"key+50": 100
}
]
Rust (jsonpath_plus)
[]
Scala (jsonpath)
[
{
"key+50": 100
}
]
Swift (Sextant)
[
{
"key+50": 100
}
]
dotNET (Json.NET)
[
{
"key+50": 100
}
]
dotNET (JsonCons.JsonPath)
[
{
"key": 50
}
]
dotNET (JsonPath.Net)
[
{
"key": 50
}
]
dotNET (JsonPathLib)
[]
dotNET (Manatee.Json)
[
{
"key": 50
}
]
JSON (Path_Reference_Implementation)
Not supported
--> 1:3
|
1 | $[?(@.key+50==100)]
| ^---
|
= expected unionChild, unionArrayIndex, or sliceStart
Proposal (A)
Not supported
x 1:10-1:10 ComparisonOperator
| $[?(@.key+50==100)]
| ^
| x 1:10-1:10 ScalarOperator
| | $[?(@.key+50==100)]
| | ^
| o 1:5-1:10 DocumentValue
| | $[?(@.key+50==100)]
| | ^^^^^
| o 1:5-1:10 UnaryFilterExpression
| | $[?(@.key+50==100)]
| | ^^^^^
| | x 1:10-1:10 ScalarOperator
| | | $[?(@.key+50==100)]
| | | ^
| | o 1:5-1:10 DocumentValue
| | | $[?(@.key+50==100)]
| | | ^^^^^
| | o 1:5-1:10 FilterValue
| | | $[?(@.key+50==100)]
| | | ^^^^^
| | |
|/ /
| |
|/
o 1:5-1:10 HigherPrecedenceFilterExpression
| $[?(@.key+50==100)]
| ^^^^^
x 1:5-1:5 LogicalOr
| $[?(@.key+50==100)]
| ^
| x 1:10-1:10 ComparisonOperator
| | $[?(@.key+50==100)]
| | ^
| | x 1:10-1:10 ScalarOperator
| | | $[?(@.key+50==100)]
| | | ^
| | o 1:5-1:10 DocumentValue
| | | $[?(@.key+50==100)]
| | | ^^^^^
| | o 1:5-1:10 UnaryFilterExpression
| | | $[?(@.key+50==100)]
| | | ^^^^^
| | | x 1:10-1:10 ScalarOperator
| | | | $[?(@.key+50==100)]
| | | | ^
| | | o 1:5-1:10 DocumentValue
| | | | $[?(@.key+50==100)]
| | | | ^^^^^
| | | o 1:5-1:10 FilterValue
| | | | $[?(@.key+50==100)]
| | | | ^^^^^
| | | |
| |/ /
| | |
| |/
| o 1:5-1:10 HigherPrecedenceFilterExpression
| | $[?(@.key+50==100)]
| | ^^^^^
| x 1:5-1:5 LogicalAnd
| | $[?(@.key+50==100)]
| | ^
| | x 1:10-1:10 ComparisonOperator
| | | $[?(@.key+50==100)]
| | | ^
| | | x 1:10-1:10 ScalarOperator
| | | | $[?(@.key+50==100)]
| | | | ^
| | | o 1:5-1:10 DocumentValue
| | | | $[?(@.key+50==100)]
| | | | ^^^^^
| | | o 1:5-1:10 UnaryFilterExpression
| | | | $[?(@.key+50==100)]
| | | | ^^^^^
| | | | x 1:10-1:10 ScalarOperator
| | | | | $[?(@.key+50==100)]
| | | | | ^
| | | | o 1:5-1:10 DocumentValue
| | | | | $[?(@.key+50==100)]
| | | | | ^^^^^
| | | | o 1:5-1:10 FilterValue
| | | | | $[?(@.key+50==100)]
| | | | | ^^^^^
| | | | |
| | |/ /
| | | |
| | |/
| | o 1:5-1:10 HigherPrecedenceFilterExpression
| | | $[?(@.key+50==100)]
| | | ^^^^^
| | |
|/ /
| |
|/
o 1:5-1:10 FilterExpression
| $[?(@.key+50==100)]
| ^^^^^
x 1:3-1:3 BracketElement
| $[?(@.key+50==100)]
| ^
x 1:3-1:3 BracketElements
| $[?(@.key+50==100)]
| ^
x 1:2-1:2 BracketChildren
| $[?(@.key+50==100)]
| ^
x 1:2-1:2 Operator
| $[?(@.key+50==100)]
| ^
o 1:1-1:2 Start
$[?(@.key+50==100)]
^
Errors
Erlang (ejsonpath)
init terminating in do_boot ({not_implemented,bin_op,+})
Crash dump is being written to: /dev/null...done
{"init terminating in do_boot",{not_implemented,bin_op,'+'}}
PHP (Goessner)
²
ArgumentCountError
Perl (JSON-Path)
non-safe evaluation, died at main.pl line 11.
Ruby (jsonpath)
String can't be coerced into Float
Footnotes
- ¹ This implementation returns a single value where only one match is possible (instead of an array of a single value).
- ² This implementation returns a specific not found value if no match exists.
- ³ This implementation returns a specific not found value if a query that would regularly return a single match results in no match.