当大小写不匹配时如何反序列化枚举?
How can I deserialize an enum when the case doesn't match?
我有一个 JSON 结构,如下所示:
{ "type": "suite", "event": "started", "test_count": 1 }
我想反序列化为这些结构:
#[derive(Debug, Deserialize)]
enum ResultType {
Suite,
Test,
}
#[derive(Debug, Deserialize)]
enum ResultEvent {
Started,
Failed,
Ok,
}
#[derive(Debug, Deserialize)]
struct JsonResult {
#[serde(rename(deserialize = "type"))]
test_type: ResultType,
event: ResultEvent,
test_count: Option<u32>,
}
我找不到让 serde_json 使用正确大小写的方法。我不断收到这些错误:
Error("unknown variant `suite`, expected `Suite` or `Test`", line: 1, column: 17)
如果我将枚举值的大小写更改为全部小写或全部大写,它会起作用,但我希望能够使用 PascalCase。
你只需要在枚举定义前加上#[serde(rename_all = "snake_case")]
。
其他可能的值是 lowercase
、UPPERCASE
、PascalCase
、camelCase
、snake_case
、SCREAMING_SNAKE_CASE
、kebab-case
, 和 SCREAMING-KEBAB-CASE
.
使用#[serde(rename = "name")]
更改序列化和反序列化时用于枚举变体的字符串。
#[derive(Debug, Deserialize)]
enum ResultType {
#[serde(rename = "suite")]
Suite,
#[serde(rename = "test")]
Test,
}
#[derive(Debug, Deserialize)]
enum ResultEvent {
#[serde(rename = "started")]
Started,
#[serde(rename = "failed")]
Failed,
#[serde(rename = "ok")]
Ok,
}
#[derive(Debug, Deserialize)]
struct JsonResult {
#[serde(rename(deserialize = "type"))]
test_type: ResultType,
event: ResultEvent,
test_count: Option<u32>,
}
你也可以使用#[serde(alias = "name")]
在反序列化时添加一个额外的字符串接受。
详细信息在 serde 文档中:https://serde.rs/variant-attrs.html
我认为骗子正在使用
#[serde(alias="Field", alias="filed", alias="FIELD")]
在田间。
因为我觉得"Field"
和"field"
和"FIELD"
是可以接受的。
和任何其他类似 "fIelD"
的情况,一定有问题。
我有一个 JSON 结构,如下所示:
{ "type": "suite", "event": "started", "test_count": 1 }
我想反序列化为这些结构:
#[derive(Debug, Deserialize)]
enum ResultType {
Suite,
Test,
}
#[derive(Debug, Deserialize)]
enum ResultEvent {
Started,
Failed,
Ok,
}
#[derive(Debug, Deserialize)]
struct JsonResult {
#[serde(rename(deserialize = "type"))]
test_type: ResultType,
event: ResultEvent,
test_count: Option<u32>,
}
我找不到让 serde_json 使用正确大小写的方法。我不断收到这些错误:
Error("unknown variant `suite`, expected `Suite` or `Test`", line: 1, column: 17)
如果我将枚举值的大小写更改为全部小写或全部大写,它会起作用,但我希望能够使用 PascalCase。
你只需要在枚举定义前加上#[serde(rename_all = "snake_case")]
。
其他可能的值是 lowercase
、UPPERCASE
、PascalCase
、camelCase
、snake_case
、SCREAMING_SNAKE_CASE
、kebab-case
, 和 SCREAMING-KEBAB-CASE
.
使用#[serde(rename = "name")]
更改序列化和反序列化时用于枚举变体的字符串。
#[derive(Debug, Deserialize)]
enum ResultType {
#[serde(rename = "suite")]
Suite,
#[serde(rename = "test")]
Test,
}
#[derive(Debug, Deserialize)]
enum ResultEvent {
#[serde(rename = "started")]
Started,
#[serde(rename = "failed")]
Failed,
#[serde(rename = "ok")]
Ok,
}
#[derive(Debug, Deserialize)]
struct JsonResult {
#[serde(rename(deserialize = "type"))]
test_type: ResultType,
event: ResultEvent,
test_count: Option<u32>,
}
你也可以使用#[serde(alias = "name")]
在反序列化时添加一个额外的字符串接受。
详细信息在 serde 文档中:https://serde.rs/variant-attrs.html
我认为骗子正在使用
#[serde(alias="Field", alias="filed", alias="FIELD")]
在田间。
因为我觉得"Field"
和"field"
和"FIELD"
是可以接受的。
和任何其他类似 "fIelD"
的情况,一定有问题。