没有内置的方法可以使用属性执行此操作,但是您可以Deserialize
为您的类型编写自己的 impl Object
,首先反序列化为一些中间帮助器表示,然后将数据重新排列到所需的结构中。
#[macro_use]
extern crate serde_derive;
extern crate serde;
extern crate serde_json;
use serde::{Deserialize, Deserializer};
#[derive(Debug)]
struct Object {
name: String,
count: i32,
foo: String,
}
impl<'de> Deserialize<'de> for Object {
fn deserialize<D>(deserializer: D) -> Result<Self, D::Error>
where D: Deserializer<'de>
{
#[derive(Deserialize)]
struct Outer {
name: String,
info: Inner,
}
#[derive(Deserialize)]
struct Inner {
count: i32,
foo: String,
}
let helper = Outer::deserialize(deserializer)?;
Ok(Object {
name: helper.name,
count: helper.info.count,
foo: helper.info.foo,
})
}
}
fn main() {
let j = r#"{
"name": "myobject",
"info": {
"count": 3,
"foo": "bar"
}
}"#;
println!("{:#?}", serde_json::from_str::<Object>(j).unwrap());
}
输出是:
Object {
name: "myobject",
count: 3,
foo: "bar"
}
在三个实质上不同的地方出现了无关紧要的嵌套:
- 与其他领域相邻
- 自己在顶层
- 本身低于顶层
这三个都需要不同的方法。在这个问题中观察到#1。
要解决 #2 或 #3,请参阅Is there a way to omit wrapper/root objects when deserializing objects with Serde?