[英]Serde Stream Deserializer for a type other than serde_json::Value
我想解析形式的 JSON 字符串
{
"a": {
"foo": "bar"
},
"b": {
"foo": "baz"
}
}
也就是说,在顶层有许多用逗号分隔的 JSON 对象。 这些对象中的每一个都具有与其他对象相同的字段(即,我可以很容易地用一个struct
表示所有这些对象)。
由于 JSON 字符串中有几个这样的对象,我相信我应该使用serde_json::StreamDeserializer
,虽然我对 Rust 和serde
比较陌生,所以如果这不是正确的方法,请指出我正确的方向。
这段代码代表了我想要做的事情:
use serde_json::Deserializer;
use serde::Deserialize;
#[derive(Deserialize, Debug)]
struct Data {
foo: String,
}
fn main() {
let data = r#"{
"a": {"foo": "bar"},
"b": {"foo": "baz"}
}"#;
let stream = Deserializer::from_str(data).into_iter::<Data>();
for value in stream {
println!("{:?}", value.unwrap());
}
}
我希望这段代码产生一些 output 类似于Object({"a": Object({"foo": String("bar")}), "b": Object({"foo": String("baz")})})
。
这是 output 我看看我是否更改了Deserializer::from_str(data).into_iter::<Data>();
到Deserializer::from_str(data).into_iter::<serde_json::Value>();
.
相反,代码无法编译,给出错误Error("missing field 'foo'", line: 4, column: 5)
那么,我需要做什么才能将 JSON 反序列化为Data
结构而不是Value
?
事实证明,解决方案比我想象的要简单得多。 感谢 Reddit 上的 /u/sfackler 向我指出这一点。
在这种情况下,我不需要使用StreamDeserializer
; 相反,我可以将 JSON 解析为HashMap
并从中提取我想要的值。
例如:
use serde::Deserialize;
use std::collections::HashMap;
#[derive(Deserialize, Debug)]
struct Data {
foo: String,
}
fn main() {
let data = r#"{
"a": {"foo": "bar"},
"b": {"foo": "baz"}
}"#;
let m: HashMap<String, Data> = serde_json::from_str(&data).unwrap();
for (_key, val) in m {
println!("{:?}", val);
}
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.