mirror of
https://github.com/fluencelabs/jsonpath
synced 2025-03-31 22:11:07 +00:00
210 lines
5.2 KiB
Markdown
210 lines
5.2 KiB
Markdown
# jsonpath-rs
|
|
|
|
[](https://travis-ci.org/freestrings/jsonpath)
|
|
|
|
It is native-addon of [jsonpath_lib](https://github.com/freestrings/jsonpath) that is [JsonPath](https://goessner.net/articles/JsonPath/) engine written in Rust.
|
|
|
|
## Notice
|
|
|
|
Pre-built 바이너리는 제공하진 않고 소스를 컴파일해서 설치한다. 만약 Rust가 설치되지 않았다면 자동으로 설치된다.
|
|
|
|
Build from source instead of using pre-built binary, and if Rust is not installed, the latest version is automatically installed.
|
|
|
|
> Not yet tested in Windows.
|
|
|
|
> Supported node version is under v12.0.
|
|
|
|
## APIs
|
|
|
|
* [jsonpath.Selector](#jsonpathselector)
|
|
* [jsonpath.select(json: string|object, jsonpath: string)](#jsonpathselectjson-stringobject-jsonpath-string)
|
|
* [jsonpath.compile(jsonpath: string)](#jsonpathcompilejsonpath-string)
|
|
* [jsonpath.selector(json: string|object)](#jsonpathselectorjson-stringobject)
|
|
* [Other Examples](https://github.com/freestrings/jsonpath/wiki/Javascript-examples)
|
|
|
|
### jsonpath.Selector
|
|
|
|
```javascript
|
|
let jsonObj = {
|
|
"school": {
|
|
"friends": [
|
|
{"name": "친구1", "age": 20},
|
|
{"name": "친구2", "age": 20}
|
|
]
|
|
},
|
|
"friends": [
|
|
{"name": "친구3", "age": 30},
|
|
{"name": "친구4"}
|
|
]
|
|
};
|
|
|
|
let selector = new jsonpath.Selector().value(jsonObj);
|
|
|
|
{
|
|
let jsonObj = selector.path('$..[?(@.age >= 30)]').selectAs();
|
|
let resultObj = [{"name": "친구3", "age": 30}];
|
|
console.log(JSON.stringify(jsonObj) === JSON.stringify(resultObj));
|
|
}
|
|
|
|
{
|
|
let jsonObj = selector.path('$..[?(@.age == 20)]').selectAs();
|
|
let resultObj = [{"name": "친구1", "age": 20}, {"name": "친구2", "age": 20}];
|
|
console.log(JSON.stringify(jsonObj) === JSON.stringify(resultObj));
|
|
}
|
|
|
|
{
|
|
let jsonObj = selector.value({"friends": [ {"name": "친구5", "age": 20} ]}).selectAs();
|
|
let resultObj = [{"name": "친구5", "age": 20}];
|
|
console.log(JSON.stringify(jsonObj) === JSON.stringify(resultObj));
|
|
}
|
|
|
|
{
|
|
let jsonObj1 = selector.value(jsonObj).map(function(v) {
|
|
let f1 = v[0];
|
|
f1.age = 30;
|
|
return v;
|
|
}).get();
|
|
|
|
let resultObj1 = [{"name": "친구1", "age": 30}, {"name": "친구2", "age": 20}];
|
|
console.log(JSON.stringify(jsonObj1) === JSON.stringify(resultObj1));
|
|
|
|
selector.path('$..[?(@.age == 20)]');
|
|
let jsonObj2 = selector.selectAs();
|
|
let resultObj2 = [{"name": "친구2", "age": 20}];
|
|
console.log(JSON.stringify(jsonObj2) === JSON.stringify(resultObj2));
|
|
}
|
|
```
|
|
|
|
### jsonpath.select(json: string|object, jsonpath: string)
|
|
|
|
```javascript
|
|
let jsonObj = {
|
|
"school": {
|
|
"friends": [
|
|
{"name": "친구1", "age": 20},
|
|
{"name": "친구2", "age": 20}
|
|
]
|
|
},
|
|
"friends": [
|
|
{"name": "친구3", "age": 30},
|
|
{"name": "친구4"}
|
|
]
|
|
};
|
|
|
|
let ret = [
|
|
{"name": "친구3", "age": 30},
|
|
{"name": "친구1", "age": 20}
|
|
];
|
|
|
|
|
|
let selectAsString = jsonpath.select(JSON.stringify(jsonObj), '$..friends[0]');
|
|
let selectAsObj = jsonpath.select(jsonObj, '$..friends[0]');
|
|
|
|
console.log(
|
|
JSON.stringify(ret) == JSON.stringify(selectAsString),
|
|
JSON.stringify(ret) == JSON.stringify(selectAsObj)
|
|
);
|
|
|
|
// => true, true
|
|
```
|
|
|
|
### jsonpath.compile(jsonpath: string)
|
|
|
|
```javascript
|
|
let template = jsonpath.compile('$..friends[0]');
|
|
|
|
let jsonObj = {
|
|
"school": {
|
|
"friends": [
|
|
{"name": "친구1", "age": 20},
|
|
{"name": "친구2", "age": 20}
|
|
]
|
|
},
|
|
"friends": [
|
|
{"name": "친구3", "age": 30},
|
|
{"name": "친구4"}
|
|
]
|
|
};
|
|
|
|
let ret = [
|
|
{"name": "친구3", "age": 30},
|
|
{"name": "친구1", "age": 20}
|
|
];
|
|
|
|
let selectAsString = template(JSON.stringify(jsonObj));
|
|
let selectAsObj = template(jsonObj);
|
|
|
|
console.log(
|
|
JSON.stringify(ret) == JSON.stringify(selectAsString),
|
|
JSON.stringify(ret) == JSON.stringify(selectAsObj)
|
|
);
|
|
|
|
// => true, true
|
|
|
|
let jsonObj2 = {
|
|
"school": {
|
|
"friends": [
|
|
{"name": "Millicent Norman"},
|
|
{"name": "Vincent Cannon"}
|
|
]
|
|
},
|
|
"friends": [ {"age": 30}, {"age": 40} ]
|
|
};
|
|
|
|
let ret2 = [
|
|
{"age": 30},
|
|
{"name": "Millicent Norman"}
|
|
];
|
|
|
|
let selectAsString2 = template(JSON.stringify(jsonObj2));
|
|
let selectAsObj2 = template(jsonObj2);
|
|
|
|
console.log(
|
|
JSON.stringify(ret2) == JSON.stringify(selectAsString2),
|
|
JSON.stringify(ret2) == JSON.stringify(selectAsObj2)
|
|
);
|
|
|
|
// => true, true
|
|
```
|
|
|
|
### jsonpath.selector(json: string|object)
|
|
|
|
```javascript
|
|
let jsonObj = {
|
|
"school": {
|
|
"friends": [
|
|
{"name": "친구1", "age": 20},
|
|
{"name": "친구2", "age": 20}
|
|
]
|
|
},
|
|
"friends": [
|
|
{"name": "친구3", "age": 30},
|
|
{"name": "친구4"}
|
|
]
|
|
};
|
|
|
|
let ret1 = [
|
|
{"name": "친구3", "age": 30},
|
|
{"name": "친구1", "age": 20}
|
|
];
|
|
|
|
let ret2 = [
|
|
{"name": "친구4"},
|
|
{"name": "친구2", "age": 20}
|
|
];
|
|
|
|
let selector = jsonpath.selector(jsonObj);
|
|
// or as json string
|
|
// let selector = jsonpath.selector(JSON.stringify(jsonObj));
|
|
|
|
let select1 = selector('$..friends[0]');
|
|
let select2 = selector('$..friends[1]');
|
|
|
|
console.log(
|
|
JSON.stringify(ret1) == JSON.stringify(select1),
|
|
JSON.stringify(ret2) == JSON.stringify(select2)
|
|
);
|
|
|
|
// => true, true
|
|
```
|