1个不稳定版本
0.1.0 | 2021年12月19日 |
---|
#1558在编码
1,748每月下载次数
24KB
440 行
valq —
valq
提供了一个用于以非常简洁的方式查询和提取结构化数据值的宏,类似于JavaScript语法。
外观和感觉
use serde_json::Value;
use valq::query_value;
let j: Value = ...;
let deep_val: Option<&Value> = query_value!(j.path.to.value.at.deep);
目前,仅导出单个宏:query_value
。
query_value
宏
查询结构化数据内部值的宏。
基本用法
// get field `foo` from JSON object `obj`
let foo = query_value!(obj.foo);
// get nested field `bar` inside object `foo` in JSON object `obj`
let bar = query_value!(obj.foo.bar);
// get head of JSON array 'arr'
let head = query_value!(arr[0]);
// get head of nested JSON array `arr` in JSON object `obj`
let head = query_value!(obj.arr[0]);
// more complex example!
let abyss = query_value!(obj.path.to.matrix[0][1].abyss);
转换为指定类型
// try to convert extracted value to `u64` by `as_u64()` method on that value.
// results in `None` in case of type mismatch
let foo_u64: Option<u64> = query_value!(obj.foo -> u64)
// in case of mutable reference extraction (see below), `as_xxx_mut()` method will be used.
let arr_vec: Option<&mut Vec<Value>> = query_value!(mut obj.arr -> array)
提取内部值的可变引用
use serde_json::{json, Value}
let mut obj = json!({"foo": { "bar": { "x": 1, "y": 2 }}});
{
// prefixed `mut` means extracting mutable reference
let bar: &mut Value = query_value!(mut obj.foo.bar).unwrap();
*bar = json!({"x": 100, "y": 200});
}
assert_eq!(query_value!(obj.foo.bar.x -> u64), Some(100));
assert_eq!(query_value!(obj.foo.bar.y -> u64), Some(200));