繁体   English   中英

Serde Stream serde_json::Value 以外的类型的反序列化器

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM