pub fn get<'de, Input, Path: IntoIterator>(
json: Input,
path: Path,
) -> Result<LazyValue<'de>>
Expand description
Gets a field from a path
. And return it as a Result<LazyValue>
.
If not found, return an error. If the path
is empty, return the whole JSON as a LazyValue
.
The Item
of the path
should implement the Index
trait.
The input json
is allowed to be &FastStr
, &[u8]
, &str
, &String
or &bytes::Bytes
.
§Safety
The JSON must be valid and well-formed, otherwise it may return unexpected result.
§Examples
use bytes::Bytes;
use faststr::FastStr;
use sonic_rs::get;
let lv = get(r#"{"a": 1}"#, &["a"]).unwrap();
assert_eq!(lv.as_raw_str(), "1");
/// not found the field "a"
let fs = FastStr::new(r#"{"a": 1}"#);
let lv = get(&fs, &["b"]);
assert!(lv.is_err());
/// the JSON is invalid
let b = Bytes::from(r#"{"a": tru }"#);
let lv = get(&b, &["a"]);
assert!(lv.is_err());