1

例如:

#[macro_use]
extern crate serde_derive;
extern crate toml;

#[derive(Deserialize)]
struct Entry {
    foo: String,
    bar: String,
}

let toml_string = r#"
  [[entry]]
  foo = "a0"
  bar = "b0"

  [[entry]]
  foo = "a1"
  bar = "b1"
  "#;
let config: toml::value::Table<Entry> = toml::from_str(&toml_string)?;

但是,这不起作用,并且会引发关于意外类型参数的错误Table

4

1 回答 1

3

打印任意解析值会显示您拥有的结构:

let config: toml::Value = toml::from_str(&toml_string)?;
println!("{:?}", config)

重新格式化的输出显示您有一个具有单个键的表,该表是具有键和entry的表的数组:foobar

Table({
  "entry": Array([
    Table({
      "bar": String("b0"),
      "foo": String("a0")
    }),
    Table({
      "bar": String("b1"),
      "foo": String("a1")
    })
  ])
})

反序列化时,需要匹配这个结构:

#[derive(Debug, Deserialize)]
struct Outer {
    entry: Vec<Entry>,
}

#[derive(Debug, Deserialize)]
struct Entry {
    foo: String,
    bar: String,
}
let config: Outer = toml::from_str(&toml_string)?;
于 2020-01-17T20:58:58.557 回答