2个版本
0.8.24 | 2022年6月5日 |
---|---|
0.8.17 | 2021年3月27日 |
#714 in 编码
3,930 每月下载次数
175KB
4K SLoC
Serde YAML (with quirks)
此serde-yaml分支实现了golang兼容的八进制解析奇偶性,此功能在上游未被接受,但在jrsonnet的golang实现兼容性中是必需的
请参阅此处:https://github.com/dtolnay/serde-yaml/pull/225
这是一个Rust库,用于使用Serde序列化框架,以YAML文件格式处理数据。
此库没有重新实现YAML解析器;它使用yaml-rust,这是一个纯Rust YAML 1.2实现。
依赖
[dependencies]
serde = "1.0"
serde_yaml = "0.8"
发布说明可在GitHub发布下找到。
使用Serde YAML
API文档以rustdoc形式提供,但基本思路是
use std::collections::BTreeMap;
fn main() -> Result<(), serde_yaml::Error> {
// You have some type.
let mut map = BTreeMap::new();
map.insert("x".to_string(), 1.0);
map.insert("y".to_string(), 2.0);
// Serialize it to a YAML string.
let s = serde_yaml::to_string(&map)?;
assert_eq!(s, "---\nx: 1.0\ny: 2.0\n");
// Deserialize it back to a Rust type.
let deserialized_map: BTreeMap<String, f64> = serde_yaml::from_str(&s)?;
assert_eq!(map, deserialized_map);
Ok(())
}
它也可以与Serde的derive宏一起使用,以处理您程序中定义的结构体和枚举。
[dependencies]
serde = { version = "1.0", features = ["derive"] }
serde_yaml = "0.8"
use serde::{Serialize, Deserialize};
#[derive(Debug, PartialEq, Serialize, Deserialize)]
struct Point {
x: f64,
y: f64,
}
fn main() -> Result<(), serde_yaml::Error> {
let point = Point { x: 1.0, y: 2.0 };
let s = serde_yaml::to_string(&point)?;
assert_eq!(s, "---\nx: 1.0\ny: 2.0\n");
let deserialized_point: Point = serde_yaml::from_str(&s)?;
assert_eq!(point, deserialized_point);
Ok(())
}
许可证
许可协议为Apache License, Version 2.0或MIT license,由您选择。除非您明确声明,否则根据Apache-2.0许可证定义的,您有意提交以包含在此软件包中的任何贡献,应按上述方式双许可,不附加任何其他条款或条件。
依赖
~1.5MB
~30K SLoC