Rust:
Arbeider med YAML
Hvordan:
Rust støtter ikke YAML i sitt standardbibliotek, så vi bruker vanligvis tredjepartsbiblioteker som serde
(for serialisering og deserialisering av data) i kombinasjon med serde_yaml
.
Først, legg til avhengigheter i din Cargo.toml
:
[dependencies]
serde = { version = "1.0", features = ["derive"] }
serde_yaml = "0.8"
Nå, la oss se på hvordan man deserialiserer en YAML-streng til en Rust-struktur og serialiserer en Rust-struktur tilbake til en YAML-streng.
Deserialisere YAML til Rust-strukturer
Definer en Rust-struktur som speiler dataene du forventer i YAML. Bruk Serde-attributter for tilpasning om nødvendig.
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);
}
Eksempelutdata ved kjøring av ovennevnte Rust-kode vil være:
Config { name: "Shield", durability: 300, owner: Owner { name: "Steve", age: 25 } }
Serialisere Rust-strukturer til YAML
Dette eksemplet tar Config
-strukturen fra forrige seksjon og serialiserer den tilbake til YAML-format.
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);
}
Forventet utdata vil være en YAML-formatert streng:
---
name: Axe
durability: 120
owner:
name: Alex
age: 30
Disse kodestykkene demonstrerer hvordan du effektivt kan integrere YAML-analyse og -generering i dine Rust-applikasjoner, ved bruk av de populære serde
og serde_yaml
-bibliotekene, imøtekomme komplekse datastrukturer og tilby enkle, menneskelesbare konfigurasjoner.