Rust:
Praca z YAML
Jak to zrobić:
Rust nie obsługuje YAML w swojej bibliotece standardowej, dlatego powszechnie używamy zewnętrznych skrzyńek, takich jak serde
(do serializacji i deserializacji danych) w połączeniu z serde_yaml
.
Najpierw dodaj zależności do swojego Cargo.toml
:
[dependencies]
serde = { version = "1.0", features = ["derive"] }
serde_yaml = "0.8"
Teraz zobaczmy, jak deserializować ciąg YAML do struktury Rust i serializować strukturę Rust z powrotem do ciągu YAML.
Deserializacja YAML do struktur Rust
Zdefiniuj strukturę Rust, która odzwierciedla dane, jakich oczekujesz w YAML. Użyj atrybutów Serde do dostosowania, jeśli jest to potrzebne.
use serde::{Deserialize, Serialize};
use serde_yaml;
#[derive(Debug, PartialEq, Serialize, Deserialize)]
struct Config {
name: String,
durability: i32,
owner: Owner,
}
#[derive(Debug, PartialEq, Serialize, Deserialize)]
struct Owner {
name: String,
age: i32,
}
fn main() {
let yaml_data = "
name: Shield
durability: 300
owner:
name: Steve
age: 25
";
let deserialized_config: Config = serde_yaml::from_str(yaml_data).unwrap();
println!("{:?}", deserialized_config);
}
Przykładowe wyjście po uruchomieniu powyższego kodu Rust będzie takie:
Config { name: "Shield", durability: 300, owner: Owner { name: "Steve", age: 25 } }
Serializacja struktur Rust do YAML
Ten przykład bierze strukturę Config
z poprzedniej sekcji i serializuje ją z powrotem do formatu YAML.
fn main() {
let config = Config {
name: String::from("Axe"),
durability: 120,
owner: Owner {
name: String::from("Alex"),
age: 30,
},
};
let serialized_yaml = serde_yaml::to_string(&config).unwrap();
println!("{}", serialized_yaml);
}
Oczekiwane wyjście będzie ciągiem sformatowanym w YAML:
---
name: Axe
durability: 120
owner:
name: Alex
age: 30
Te fragmenty kodu demonstrują, jak efektywnie zintegrować parsowanie i generowanie YAML w twoich aplikacjach Rust, używając popularnych skrzynek serde
i serde_yaml
, umożliwiając obsługę złożonych struktur danych i zapewniając proste, czytelne konfiguracje.