Rust
버전 JsonPath 구현이다. Webassembly
와 Javascript
에서도 유사한 API 인터페이스를 제공 한다.
It is JsonPath JsonPath engine written in Rust
. it provide a similar API interface in Webassembly
andJavascript
also.
```rust extern crate jsonpath_lib as jsonpath;
extern crate serde_json; ```
```rust
struct Friend {
name: String,
age: Option
let json_obj = json!({ "school": { "friends": [ {"name": "친구1", "age": 20}, {"name": "친구2", "age": 20} ] }, "friends": [ {"name": "친구3", "age": 30}, {"name": "친구4"} ]});
let mut selector = Selector::new();
let result = selector .path("$..[?(@.age >= 30)]").unwrap() // .valuefromstr(&serdejson::tostring(&jsonobj).unwrap() /*&str*/).unwrap() // .valuefrom(&jsonobj /*&impl serde::ser::Serialize*/).unwrap() .value((&jsonobj /serde_json::value::Value/ ).into()).unwrap() .selecttovalue().unwrap();
assert_eq!(json!([{"name": "친구3", "age": 30}]), result);
let result = selector.selecttostr().unwrap(); assert_eq!(r#"[{"name":"친구3","age":30}]"#, result);
let result = selector.selectto::
```rust let json_obj = json!({ "school": { "friends": [ {"name": "친구1", "age": 20}, {"name": "친구2", "age": 20} ] }, "friends": [ {"name": "친구3", "age": 30}, {"name": "친구4"} ]});
let json = jsonpath::select(&json_obj, "$..friends[0]").unwrap();
let ret = json!([ {"name": "친구3", "age": 30}, {"name": "친구1", "age": 20} ]); assert_eq!(json, ret); ```
```rust let ret = jsonpath::selectasstr(r#" { "school": { "friends": [ {"name": "친구1", "age": 20}, {"name": "친구2", "age": 20} ] }, "friends": [ {"name": "친구3", "age": 30}, {"name": "친구4"} ] } "#, "$..friends[0]").unwrap();
assert_eq!(ret, r#"[{"name":"친구3","age":30},{"name":"친구1","age":20}]"#); ```
```rust
struct Person {
name: String,
age: u8,
phones: Vec
let ret: Person = jsonpath::select_as(r#" { "person": { "name": "Doe John", "age": 44, "phones": [ "+44 1234567", "+44 2345678" ] } } "#, "$.person").unwrap();
let person = Person { name: "Doe John".tostring(), age: 44, phones: vec!["+44 1234567".tostring(), "+44 2345678".to_string()], };
assert_eq!(person, ret); ```
```rust let mut template = jsonpath::compile("$..friends[0]");
let json_obj = json!({ "school": { "friends": [ {"name": "친구1", "age": 20}, {"name": "친구2", "age": 20} ] }, "friends": [ {"name": "친구3", "age": 30}, {"name": "친구4"} ]});
let json = template(&json_obj).unwrap();
let ret = json!([ {"name": "친구3", "age": 30}, {"name": "친구1", "age": 20} ]);
assert_eq!(json, ret); ```
```rust let json_obj = json!({ "school": { "friends": [ {"name": "친구1", "age": 20}, {"name": "친구2", "age": 20} ] }, "friends": [ {"name": "친구3", "age": 30}, {"name": "친구4"} ]});
let mut selector = jsonpath::selector(&json_obj);
let json = selector("$..friends[0]").unwrap();
let ret = json!([ {"name": "친구3", "age": 30}, {"name": "친구1", "age": 20} ]);
assert_eq!(json, ret);
let json = selector("$..friends[1]").unwrap();
let ret = json!([ {"name": "친구4"}, {"name": "친구2", "age": 20} ]);
assert_eq!(json, ret); ```
```rust let json_obj = json!({ "school": { "friends": [ {"name": "친구1", "age": 20}, {"name": "친구2", "age": 20} ] }, "friends": [ {"name": "친구3", "age": 30}, {"name": "친구4"} ]});
struct Friend {
name: String,
age: Option
let mut selector = jsonpath::selectoras::
let json = selector("$..friends[0]").unwrap();
let ret = vec!( Friend { name: "친구3".tostring(), age: Some(30) }, Friend { name: "친구1".tostring(), age: Some(20) } ); assert_eq!(json, ret);
let json = selector("$..friends[1]").unwrap();
let ret = vec!( Friend { name: "친구4".tostring(), age: None }, Friend { name: "친구2".tostring(), age: Some(20) } );
assert_eq!(json, ret); ```
javascript
// browser
import * as jsonpath from "jsonpath-wasm";
// NodeJs
const jsonpath = require('jsonpath-wasm');
javascript
const jsonpath = require('jsonpath-rs');
wasm-bindgen
리턴 타입 제약 때문에 빌더 패턴은 지원하지 않는다.
It does not support builder-pattern
due to the return type
restriction of wasm-bindgen
.
```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 selector = new jsonpath.Selector(); selector.path('$..friends[0]'); selector.value(jsonObj);
let selectToObj = selector.selectTo(); let selectToString = selector.selectToStr();
console.log( JSON.stringify(ret) == JSON.stringify(selectToObj), JSON.stringify(ret) == selectToString );
// => true, true ```
```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 selector = new jsonpath.Selector() .path('$..friends[0]') .value(jsonObj);
let selectToObj = selector.selectTo(); let selectToString = selector.selectToStr();
console.log( JSON.stringify(ret) == JSON.stringify(selectToObj), JSON.stringify(ret) == selectToString );
// => true, true ```
```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 ```
```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 ```
```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 ```
wasm-bindgen은 Javascript와 Webassembly간 값을 주고받을 때 JSON 객체는 String으로 변환되기 때문에, 반복해서 사용되는 JSON 객체는 Webassembly 영역에 생성해 두면 성능에 도움이 된다.
Since wasm-bindgen converts JSON objects to String when exchanging values between Javascript and Webassembly, creating frequently used JSON objects in the WebAssembly area helps performance.
```javascript const jsonpath = require('jsonpath-wasm');
let jsonObj = { "school": { "friends": [ {"name": "친구1", "age": 20}, {"name": "친구2", "age": 20} ] }, "friends": [ {"name": "친구3", "age": 30}, {"name": "친구4"} ] };
// allocate jsonObj in webassembly let ptr = jsonpath.allocJson(jsonObj);
// 0
is invalid pointer
if(ptr == 0) {
console.error('invalid ptr');
}
let path = '$..friends[0]'; let template = jsonpath.compile(path); let selector = jsonpath.selector(jsonObj); // create selector as pointer let ptrSelector = jsonpath.selector(ptr);
let ret1 = selector(path) let ret2 = ptrSelector(path) let ret3 = template(jsonObj); // select as pointer let ret4 = template(ptr); let ret5 = jsonpath.select(jsonObj, path); // select as pointer let ret6 = jsonpath.select(ptr, path);
console.log( JSON.stringify(ret1) == JSON.stringify(ret2), JSON.stringify(ret1) == JSON.stringify(ret3), JSON.stringify(ret1) == JSON.stringify(ret4), JSON.stringify(ret1) == JSON.stringify(ret5), JSON.stringify(ret1) == JSON.stringify(ret6));
// => true true true true true
jsonpath.deallocJson(ptr); ```